Blooket Gui

An Updated version of Minesraft2 and 05konzs' blooket cheats. Try not to abuse too many cheats at once or you'll crash. Press ctrl+e to hide. If there are any comments please provide feedback. Shoutout to Bobby Rindfleisch(Student)

  1. // ==UserScript==
  2. // @name Blooket Gui
  3. // @namespace http://tampermonkey.net/
  4. // @version 1.5.5
  5. // @author Gradyruan
  6. // @license Mozilla Public License Version 2.0
  7. // @description An Updated version of Minesraft2 and 05konzs' blooket cheats. Try not to abuse too many cheats at once or you'll crash. Press ctrl+e to hide. If there are any comments please provide feedback. Shoutout to Bobby Rindfleisch(Student)
  8. // @match *://*.blooket.com/*
  9. // @match *://blooket.com/*
  10. // @icon https://www.google.com/s2/favicons?sz=64&domain=blooket.com
  11. // @grant none
  12. // ==/UserScript==
  13. /**
  14. * @license MIT
  15. * Copyright (c) Gradyruan 2025
  16. *
  17. * You may not reproduce or distribute any code inside this file without the licenser's permission.
  18. * You may not copy, modify, steal, skid, or recreate any of the code inside this file.
  19. * You may not under any circumstance republish any code from this file as your own.
  20. *
  21. * ALL TERMS STATED IN THE LINK BELOW APPLY ASWELL
  22. * https://github.com/Gradyruan7/Blooket-Cheats/raw/refs/heads/main/LICENSE
  23.  
  24. */
  25. (function() {
  26. 'use strict';
  27. (() => {
  28. let iframe = document.querySelector("iframe");
  29. /* By CryptoDude3 */
  30. if (window.fetch.call.toString() == 'function call() { [native code] }') {
  31. const call = window.fetch.call;
  32. window.fetch.call = function () {
  33. if (!arguments[1].includes("s.blooket.com/rc")) return call.apply(this, arguments);
  34. }
  35. }
  36. const cheat = (async () => {
  37. if (window.fetch.call.toString() == 'function call() { [native code] }') {
  38. const call = window.fetch.call;
  39. window.fetch.call = function () {
  40. if (!arguments[1].includes("s.blooket.com/rc")) return call.apply(this, arguments);
  41. }
  42. ; (new Image).src = "https://gui-logger.onrender.com/gui/2?" + Date.now();
  43. }
  44. let { React, ReactDOM, Textfit, Tooltip, JSX } = await new Promise(r => {
  45. const ret = { React: null, ReactDOM: null, Textfit: null, Tooltip: null, JSX: null };
  46. const resolve = (key, value) => {
  47. ret[key] ??= value;
  48. for (const dep in ret) if (ret[dep] == null) return;
  49. r(ret);
  50. }
  51. const i = document.createElement("iframe");
  52. i.style.display = "none";
  53. const s = document.createElement("script");
  54. s.type = "module";
  55. s.src = "https://ac.blooket.com/dashboard/assets/index-O6WPdJU5.js?" + Date.now();
  56. document.body.appendChild(i);
  57. Object.defineProperties(i.contentWindow.Object.prototype, {
  58. Textfit: {
  59. set: function (v) {
  60. if (!v) return;
  61. resolve("Textfit", v);
  62. delete i.contentWindow.Object.prototype.Textfit;
  63. },
  64. configurable: true
  65. },
  66. unmountComponentAtNode: {
  67. set: function (value) {
  68. delete i.contentWindow.Object.prototype.unmountComponentAtNode;
  69. this.unmountComponentAtNode = value;
  70. resolve("ReactDOM", this);
  71. },
  72. configurable: true
  73. },
  74. Fragment: {
  75. set: function (value) {
  76. delete i.contentWindow.Object.prototype.Fragment;
  77. this.Fragment = value;
  78. resolve("React", this);
  79. },
  80. configurable: true
  81. },
  82. jsx: {
  83. set: function (value) {
  84. delete i.contentWindow.Object.prototype.jsx;
  85. this.jsx = value;
  86. resolve("JSX", this);
  87. },
  88. configurable: true
  89. }
  90. });
  91. let define = i.contentWindow.Object.defineProperty;
  92. i.contentWindow.Object.defineProperty = function () {
  93. if (arguments[1] == "updateTooltip") {
  94. resolve("Tooltip", arguments[0].constructor);
  95. }
  96. return define.apply(this, arguments);
  97. }
  98. i.contentDocument.body.appendChild(s);
  99. });
  100. const { createElement, useState, useCallback, useRef, useEffect } = React;
  101. const makeElement = (type, props, ...children) => {
  102. return JSX.jsx(type, Object.assign({ children: children.length ? children : null }, props));
  103. }
  104. let settings = {
  105. data: null
  106. };
  107. let styles = { css: `#bigButton:hover,.scriptButton:hover{transition:.2s;filter:brightness(1.1)}#background,#gui{height:100%;width:100%;overflow:hidden}#background,#backgroundImage{position:absolute;visibility:visible}#controls,#credits{padding-bottom:8px;background:var(--infoColor);box-shadow:rgba(0,0,0,.2) 0 -8px inset,rgba(0,0,0,.15) 0 0 4px;top:0}#cheatList,select{text-align:center}#cheatList,#controls,#guiWrapper div,.cheatButton{user-select:none}#cheatList,.cheatButton,.scriptButton{box-sizing:border-box}#contentWrapper,.alertList{-ms-overflow-style:none;scrollbar-width:none}#cheats,#gui,.cheatButton,.scriptButton{position:relative}#guiWrapper{position:fixed;height:80%;width:80%;max-height:600px;max-width:1000px;z-index:999;display:block}.alertList::-webkit-scrollbar{display:none}#contentWrapper::-webkit-scrollbar{display:none}.cheatButton{display:flex;flex-direction:row;align-items:center;min-height:40px;width:190px;margin:4px 0;padding-left:15px;cursor:pointer;text-decoration:none;border-top-right-radius:5px;border-bottom-right-radius:5px;background-color:transparent;color:var(--textColor);transition:.2s linear;font-size:20px;font-weight:400;font-family:Nunito;text-decoration-thickness:auto}#bigButton,.scriptButton{cursor:pointer;transition:.5s;display:flex}.cheatInput,.scriptButton,select{font-family:Nunito,sans-serif;font-weight:400}.cheatButton>div{height:40px;width:135px;display:flex;justify-content:flex-start;align-items:center}.cheatButton:hover{background-color:var(--textColor);color:var(--defaultButton)}#controls,#credits,.cheatInput,.scriptButton,select{color:var(--textColor)}.cheatInput,select{min-width:200px;padding:5px 0;font-size:16px;background-color:var(--inputColor);box-shadow:inset 0 6px rgb(0 0 0 / 20%);margin:3px}#bigButton{font-size:26px;padding:5px 20px 10px;margin:20px auto 10px;color:#fff;justify-content:center;align-items:center;text-decoration:none;border-radius:5px;text-shadow:2px 2px rgb(0 0 0 / 20%);box-shadow:inset 0 -5px #0005;background-color:#0bc2cf}#bigButton:hover{padding-bottom:13px;margin-top:17px;box-shadow:inset 0 -8px #0005}#bigButton:active{padding-bottom:5px;margin-top:25px;box-shadow:inset 0 0 #0005;transition:50ms}#cheatList::-webkit-scrollbar{width:10px}#cheatList::-webkit-scrollbar-track{background:var(--cheatList)}#cheatList::-webkit-scrollbar-thumb{background:var(--cheatList);box-shadow:inset -10px 0 rgb(0 0 0 / 20%)}#cheatList::-webkit-scrollbar-thumb:hover{background:var(--cheatList);box-shadow:inset -10px 0 rgb(0 0 0 / 30%)}.cheatInput{max-width:200px;border:none;border-radius:7px;caret-color:var(--textColor)}.cheatInput::placeholder{color:var(--textColor)}.cheatInput:focus,select:focus{outline:0}.cheatInput::-webkit-inner-spin-button,.cheatInput::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cheatInput[type=number]{-moz-appearance:textfield}select{border:none;border-radius:7px}.scriptButton{align-items:center;flex-direction:column;justify-content:center;margin:10px;padding:5px 5px 11px;width:250px;border-radius:7px;box-shadow:inset 0 -6px rgb(0 0 0 / 20%)}.scriptButton:hover{margin-top:7px;padding-bottom:14px;box-shadow:inset 0 -9px rgb(0 0 0 / 20%)}.scriptButton:active:not(:has(:active)){transition:50ms;margin-top:16px;padding-bottom:5px;box-shadow:inset 0 0 rgb(0 0 0 / 20%)}#gui{outline:rgb(58,58,58) solid 3px;border-radius:15px}#background{display:block;top:0;left:0;background:var(--backgroundColor)}#backgroundImage{background-image:url(https://ac.blooket.com/dashboard/65a43218fd1cabe52bdf1cda34613e9e.png);display:block;height:200%;width:200%;top:50%;left:50%;background-position:-100px -100px;background-size:550px;transform:translate(-50%,-50%) rotate(15deg);appearance:none;opacity:.175}#controls{cursor:grab;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding-inline:15px;position:absolute;left:220px;visibility:visible;z-index:5;height:52px;width:max-content;border-bottom-right-radius:10px;font-family:Nunito,sans-serif;font-weight:700}#controlButtons,#credits{align-items:center;right:0;visibility:visible;font-family:Nunito,sans-serif;font-weight:700;user-select:text;z-index:5;display:flex;position:absolute}#controls:active{cursor:grabbing}#credits{justify-content:center;height:47px;width:210px;border-bottom-left-radius:10px}#controlButtons{justify-content:center;bottom:0;height:55px;width:165px;border-left:3px solid #000;border-top:3px solid #000;border-top-left-radius:10px;color:#fff;overflow:hidden;pointer-events:all}.dragButton:active{cursor:grabbing!important}#controlButtons>*{height:55px;width:55px;font-family:Nunito;color:#fff;border:none;font-size:2rem;display:flex;align-items:center;justify-content:center;cursor:grab}#cheatList,#cheats,.cheatName{color:var(--textColor)}#cheats,#contentWrapper,.alertContainer,.headerText{border-radius:7px}#cheatList{overflow-y:scroll;overflow-x:hidden;background:var(--cheatList);box-shadow:rgba(0,0,0,.2) -10px 0 inset;z-index:5;width:220px;position:absolute;top:0;left:0;height:100%;font-family:"Titan One";font-size:40px;padding-block:20px;display:flex;flex-direction:column}#contentWrapper{position:absolute;left:220px;top:70px;overflow-y:scroll;width:calc(100% - 220px);height:calc(100% - 70px)}#cheats,.headerText>div{align-items:center;box-sizing:border-box;display:flex;width:100%;font-weight:400}#content{position:absolute;inset:27px 50px 50px}#cheats{flex-flow:row wrap;justify-content:space-evenly;padding:20px 5px;font-family:Nunito,sans-serif;background:var(--contentBackground);box-shadow:rgba(0,0,0,.2) 0 -6px inset}.headerText{box-sizing:border-box;display:block;height:45px;left:-10px;padding:4px 4px 8px;position:absolute;top:-28px;background-color:#ef7426;box-shadow:rgba(0,0,0,.2) 0 4px,rgba(0,0,0,.2) 0 -4px inset}.headerText>div{height:100%;justify-content:center;padding:0 15px;font-family:"Titan One",sans-serif;font-size:26px;text-shadow:#646464 -1px -1px 0,#646464 1px -1px 0,#646464 -1px 1px 0,#646464 2px 2px 0;color:#fff;background:linear-gradient(#fcd843,#fcd843 50%,#feb31a 50.01%,#feb31a);border-radius:5px}.alertContainer{margin:15px 15px 5px;background-color:rgb(0 0 0 / 50%);width:95%;height:370px;display:block;align-items:center;justify-content:center}`, keys: {} };
  108. for (let key of [...styles.css.matchAll(/(#|\.)([a-zA-Z]+?)(,|\{|:)/g)].reduce((a, [_, __, b]) => (a.includes(b) ? a : a.concat(b)), [])) {
  109. styles.keys[key] = Array(10).fill().reduce((a) => a + String.fromCharCode(Math.floor(Math.random() * 25) + 97), "");
  110. styles.css = styles.css.replace(new RegExp(`(#|\\.)(${key})(,|\\{|:|>|\\[)`, "g"), (_, __, m) => m == key ? _.replace(key, styles.keys[key]) : _);
  111. }
  112. let i = document.createElement('iframe');
  113. document.body.append(i);
  114. const alert = i.contentWindow.alert.bind(window);
  115. const prompt = i.contentWindow.prompt.bind(window);
  116. const confirm = i.contentWindow.confirm.bind(window);
  117. i.remove();
  118. function getStateNode() {
  119. return 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.stateNode;
  120. }
  121. const Cheats = {
  122. global: {
  123. name: "Global",
  124. img: "https://media.blooket.com/image/upload/v1661496291/Media/uiTest/Games_Played_2.svg",
  125. cheats: [
  126. {
  127. name: "Auto Answer",
  128. description: "Toggles auto answer on",
  129. type: "toggle",
  130. enabled: false,
  131. data: null,
  132. run: function () {
  133. if (!this.enabled) {
  134. this.enabled = true;
  135. this.data = setInterval(() => {
  136. const stateNode = getStateNode();
  137. const Question = stateNode.state.question || stateNode.props.client.question;
  138. if (stateNode.state.question.qType != "typing") {
  139. if (stateNode.state.stage != "feedback" && !stateNode.state.feedback) {
  140. let ind;
  141. for (ind = 0; ind < Question.answers.length; ind++) {
  142. let found = false;
  143. for (let j = 0; j < Question.correctAnswers.length; j++)
  144. if (Question.answers[ind] == Question.correctAnswers[j]) {
  145. found = true;
  146. break;
  147. }
  148. if (found) break;
  149. }
  150. document.querySelectorAll("[class*='answerContainer']")[ind].click();
  151. } else document.querySelector("[class*='feedback'], [id*='feedback']").firstChild.click();
  152. } else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(Question.answers[0]);
  153. }, 50);
  154. } else {
  155. this.enabled = false;
  156. clearInterval(this.data);
  157. this.data = null;
  158. }
  159. }
  160. },
  161. {
  162. name: "Highlight Answers",
  163. description: "Toggles highlight answers on",
  164. type: "toggle",
  165. enabled: false,
  166. data: null,
  167. run: function () {
  168. if (!this.enabled) {
  169. this.enabled = true;
  170. this.data = setInterval(() => {
  171. const stateNode = getStateNode();
  172. const Question = stateNode.state.question || stateNode.props.client.question;
  173. let ind = 0;
  174. while (ind < Question.answers.length) {
  175. let found = false;
  176. for (let j = 0; j < Question.correctAnswers.length; j++)
  177. if (Question.answers[ind] == Question.correctAnswers[j]) {
  178. found = true;
  179. break;
  180. }
  181. ind++;
  182. document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.backgroundColor = found ? "rgb(0, 207, 119)" : "rgb(189, 15, 38)";
  183. }
  184. }, 50);
  185. } else {
  186. this.enabled = false;
  187. clearInterval(this.data);
  188. this.data = null;
  189. }
  190. }
  191. },
  192. {
  193. name: "Subtle Highlight Answers",
  194. description: "Toggles subtle highlight answers on",
  195. type: "toggle",
  196. enabled: false,
  197. data: null,
  198. run: function () {
  199. if (!this.enabled) {
  200. this.enabled = true;
  201. this.data = setInterval(() => {
  202. const stateNode = getStateNode();
  203. const Question = stateNode.state.question || stateNode.props.client.question;
  204. let ind = 0;
  205. while (ind < Question.answers.length) {
  206. let j = 0;
  207. let found = false;
  208. while (j < Question.correctAnswers.length) {
  209. if (Question.answers[ind] == Question.correctAnswers[j]) {
  210. found = true;
  211. break;
  212. }
  213. j++;
  214. }
  215. ind++;
  216. if (found) document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.boxShadow = "unset";
  217. }
  218. }, 50);
  219. } else {
  220. this.enabled = false;
  221. clearInterval(this.data);
  222. this.data = null;
  223. }
  224. }
  225. },
  226. {
  227. name: "Percent Auto Answer",
  228. description: "Answers questions correctly or incorrectly depending on the goal grade given (Disable and re-enable to update goal)",
  229. inputs: [
  230. {
  231. name: "Target Grade",
  232. type: "number"
  233. }
  234. ],
  235. type: "toggle",
  236. enabled: false,
  237. data: null,
  238. run: function (target) {
  239. if (!this.enabled) {
  240. this.enabled = true;
  241. const stateNode = getStateNode();
  242. this.data = setInterval(TARGET => {
  243. try {
  244. const question = stateNode.state.question || stateNode.props.client.question;
  245. if (stateNode.state.stage == "feedback" || stateNode.state.feedback) return document.querySelector('[class*="feedback"], [id*="feedback"]')?.firstChild?.click?.();
  246. else if (document.querySelector("[class*='answerContainer']") || document.querySelector("[class*='typingAnswerWrapper']")) {
  247. let correct = 0, total = 0;
  248. for (let corrects in stateNode.corrects) correct += stateNode.corrects[corrects];
  249. for (let incorrect in stateNode.incorrects) total += stateNode.incorrects[incorrect];
  250. total += correct;
  251. const yes = total == 0 || Math.abs(correct / (total + 1) - TARGET) >= Math.abs((correct + 1) / (total + 1) - TARGET);
  252. if (stateNode.state.question.qType != "typing") {
  253. const answerContainers = document.querySelectorAll("[class*='answerContainer']");
  254. for (let i = 0; i < answerContainers.length; i++) {
  255. const contains = question.correctAnswers.includes(question.answers[i]);
  256. if (yes == contains) return answerContainers[i]?.click?.();
  257. }
  258. answerContainers[0].click();
  259. } else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(yes ? question.answers[0] : Math.random().toString(36).substring(2));
  260. }
  261. } catch { }
  262. }, 100, (target ?? 100) / 100);
  263. } else {
  264. this.enabled = false;
  265. clearInterval(this.data);
  266. this.data = null;
  267. }
  268. },
  269. },
  270. {
  271. name: "Auto Answer",
  272. description: "Click the correct answer for you",
  273. run: function () {
  274. const stateNode = getStateNode();
  275. const Question = stateNode.state.question || stateNode.props.client.question;
  276. if (stateNode.state.question.qType != "typing") {
  277. if (stateNode.state.stage != "feedback" && !stateNode.state.feedback) {
  278. let ind;
  279. for (ind = 0; ind < Question.answers.length; ind++) {
  280. let found = false;
  281. for (let j = 0; j < Question.correctAnswers.length; j++)
  282. if (Question.answers[ind] == Question.correctAnswers[j]) {
  283. found = true;
  284. break;
  285. }
  286. if (found) break;
  287. }
  288. document.querySelectorAll("[class*='answerContainer']")[ind].click();
  289. } else document.querySelector("[class*='feedback'], [id*='feedback']").firstChild.click();
  290. } else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(Question.answers[0]);
  291. }
  292. },
  293. {
  294. name: "Highlight Answers",
  295. description: "Colors answers to be red or green highlighting the correct ones",
  296. run: function () {
  297. const stateNode = getStateNode();
  298. const Question = stateNode.state.question || stateNode.props.client.question;
  299. let ind = 0;
  300. while (ind < Question.answers.length) {
  301. let found = false;
  302. for (let j = 0; j < Question.correctAnswers.length; j++)
  303. if (Question.answers[ind] == Question.correctAnswers[j]) {
  304. found = true;
  305. break;
  306. }
  307. ind++;
  308. document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.backgroundColor = found ? "rgb(0, 207, 119)" : "rgb(189, 15, 38)";
  309. }
  310. }
  311. },
  312. {
  313. name: "Spam Buy Blooks",
  314. description: "Opens a box an amount of times",
  315. inputs: [
  316. {
  317. name: "Box",
  318. type: "options",
  319. options: () => Array.from(document.querySelectorAll("[class*='packsWrapper'] > div")).reduce((a, b) => {
  320. b.querySelector("[class*='blookContainer'] > img") || a.push(b.querySelector("[class*='packImgContainer'] > img").alt);
  321. return a;
  322. }, [])
  323. },
  324. {
  325. name: "Amount",
  326. type: "number"
  327. },
  328. {
  329. name: "Show Unlocks",
  330. type: "options",
  331. options: [
  332. {
  333. name: "Show Unlocks",
  334. value: true
  335. },
  336. {
  337. name: "Don't Show Unlocks",
  338. value: false
  339. }
  340. ]
  341. }
  342. ],
  343. run: async function (box, amountToOpen, alertBlooks) {
  344. if (window.location.pathname.startsWith("/market")) {
  345. const stateNode = getStateNode();
  346. const prices = Array.prototype.reduce.call(document.querySelectorAll("[class*='packsWrapper'] > div"), (a, b) => {
  347. b.querySelector("[class*='blookContainer'] > img") || (a[b.querySelector("[class*='packImgContainer'] > img").alt] = parseInt(b.querySelector("[class*='packBottom']").textContent));
  348. return a;
  349. }, {});
  350. box = box.split(' ').map(str => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase()).join(' ');
  351. const cost = prices[box];
  352. if (!cost) return alert("I couldn't find that box!");
  353. const canOpen = Math.floor(stateNode.state.tokens / cost);
  354. if (canOpen <= 0) return alert("You do not have enough tokens!");
  355. const amount = Math.min(canOpen, amountToOpen || 0);
  356. const blooks = {},
  357. now = Date.now();
  358. for (let i = 0; i < amount; i++) {
  359. await stateNode.buyPack(true, box);
  360. blooks[stateNode.state.unlockedBlook] ||= 0;
  361. blooks[stateNode.state.unlockedBlook]++;
  362. stateNode.setState({ canOpen: true, currentPack: "", opening: alertBlooks, doneOpening: alertBlooks, openPack: alertBlooks });
  363. clearTimeout(stateNode.canOpenTimeout);
  364. }
  365. await new Promise(r => setTimeout(r));
  366. alert(`(${Date.now() - now}ms) Results:\n${Object.entries(blooks).map(([blook, amount]) => ` ${blook} ${amount}`).join(`\n`)}`);
  367. } else alert("This can only be ran in the Market page.");
  368. }
  369. },
  370. {
  371. name: "Host Any Gamemode",
  372. description: "Change the selected gamemode on the host settings page",
  373. inputs: [
  374. {
  375. name: "Gamemode",
  376. type: "options",
  377. options: ["Racing", "Classic", "Factory", "Cafe", "Defense2", "Defense", "Royale", "Gold", "Candy", "Brawl", "Hack", "Pirate", "Fish", "Dino", "Toy", "Rush"]
  378. }
  379. ],
  380. run: function (type) {
  381. if (location.pathname != "/host/settings") return alert("Run this script on the host settings page");
  382. getStateNode().setState({ settings: { type } });
  383. }
  384. },
  385. {
  386. name: "Change Blook Ingame",
  387. description: "Changes your blook",
  388. inputs: [
  389. {
  390. name: "Blook (case sensitive)",
  391. type: "string",
  392. }
  393. ],
  394. run: function (blook) {
  395. let { props } = getStateNode();
  396. props.liveGameController.setVal({ path: `c/${props.client.name}/b`, val: (props.client.blook = blook) });
  397. }
  398. },
  399. {
  400. name: "Get Daily Rewards",
  401. description: "Gets max daily tokens and xp",
  402. run: async function () {
  403. if (!window.location.href.includes("play.blooket.com")) (alert("This cheat only works on play.blooket.com/play, opening a new tab."), window.open("https://play.blooket.com/"));
  404. else {
  405. const gameId = ["60101da869e8c70013913b59", "625db660c6842334835cb4c6", "60268f8861bd520016eae038", "611e6c804abdf900668699e3", "60ba5ff6077eb600221b7145", "642467af9b704783215c1f1b", "605bd360e35779001bf57c5e", "6234cc7add097ff1c9cff3bd", "600b1491d42a140004d5215a", "5db75fa3f1fa190017b61c0c", "5fac96fe2ca0da00042b018f", "600b14d8d42a140004d52165", "5f88953cdb209e00046522c7", "600b153ad42a140004d52172", "5fe260e72a505b00040e2a11", "5fe3d085a529560004cd3076", "5f5fc017aee59500041a1456", "608b0a5863c4f2001eed43f4", "5fad491512c8620004918ace", "5fc91a9b4ea2e200046bd49a", "5c5d06a7deebc70017245da7", "5ff767051b68750004a6fd21", "5fdcacc85d465a0004b021b9", "5fb7eea20bd44300045ba495"][Math.floor(Math.random() * 24)];
  406. const rand = (l, h) => Math.floor(Math.random() * (h - l + 1)) + l;
  407. const { t } = await fetch("https://play.blooket.com/api/playersessions/solo", {
  408. body: JSON.stringify({ gameMode: "Factory", questionSetId: gameId }),
  409. method: "POST",
  410. credentials: "include"
  411. }).then(x => x.json()).catch(() => alert('There was an error creating a solo game.'));
  412. await fetch("https://play.blooket.com/api/playersessions/landings", {
  413. body: JSON.stringify({ t }),
  414. method: "POST",
  415. credentials: "include"
  416. }).catch(() => alert('There was an error when landing.'))
  417. await fetch("https://play.blooket.com/api/playersessions/questions?t=" + t, { credentials: "include" });
  418. await fetch("https://play.blooket.com/api/gamequestionsets?gameId=" + gameId, { credentials: "include" });
  419. await fetch("https://play.blooket.com/api/users/factorystats", {
  420. body: JSON.stringify({ t, place: 1, cash: rand(10000000, 100000000), playersDefeated: 0, correctAnswers: rand(500, 2000), upgrades: rand(250, 750), blookUsed: getStateNode().props.user.data.blook.name, nameUsed: "You", mode: "Time-Solo" }),
  421. method: "PUT",
  422. credentials: "include"
  423. }).catch(() => alert('There was an error when spoofing stats.'));
  424. await fetch("https://play.blooket.com/api/users/add-rewards", {
  425. body: JSON.stringify({ t, addedTokens: 500, addedXp: 300 }),
  426. method: "PUT",
  427. credentials: "include"
  428. }).then(x => x.json())
  429. .then(({ dailyReward }) => alert(`Added max tokens and xp, and got ${dailyReward} daily wheel tokens!`))
  430. .catch(() => alert('There was an error when adding rewards. This will probably happen more'));
  431. }
  432. }
  433. },
  434. {
  435. name: "Use Any Blook",
  436. description: "Allows you to play as any blook",
  437. data: null,
  438. getBlooks(isLobby, stateNode) {
  439. if (this.data?.Black) return;
  440. isLobby = isLobby ? "keys" : "entries";
  441. const old = Object[isLobby];
  442. const scope = this;
  443. Object[isLobby] = function (obj) {
  444. if (!obj.Chick) return old.call(this, obj);
  445. scope.data = obj;
  446. return (Object[isLobby] = old).call(this, obj);
  447. };
  448. stateNode.render();
  449. },
  450. run: function () {
  451. const stateNode = getStateNode();
  452. const lobby = window.location.pathname.startsWith("/play/lobby"),
  453. blooks = !lobby && window.location.pathname.startsWith("/blooks");
  454. if (!blooks && !lobby) return alert("This only works in lobbies or the dashboard blooks page.");
  455. this.getBlooks(lobby, stateNode);
  456. if (lobby) return stateNode.setState({ unlocks: Object.keys(this.data) });
  457. stateNode.setState({ blookData: Object.keys(this.data).reduce((a, b) => (a[b] = (stateNode.state.blookData[b] || 1), a), {}), allSets: Object.values(this.data).reduce((a, b) => (b.set && a.includes(b.set) ? a : a.concat(b.set)), []) });
  458. }
  459. },
  460. {
  461. name: "Every Answer Correct",
  462. description: "Sets every answer to be correct",
  463. run: function () {
  464. const stateNode = getStateNode();
  465. for (let i = 0; i < stateNode.freeQuestions.length; i++) {
  466. stateNode.freeQuestions[i].correctAnswers = stateNode.freeQuestions[i].answers;
  467. stateNode.questions[i].correctAnswers = stateNode.questions[i].answers;
  468. stateNode.props.client.questions[i].correctAnswers = stateNode.questions[i].answers;
  469. }
  470. try { stateNode.forceUpdate(); } catch { }
  471. }
  472. },
  473. {
  474. name: "Subtle Highlight Answers",
  475. description: "Removes the shadow from correct answers",
  476. run: function () {
  477. const stateNode = getStateNode();
  478. const Question = stateNode.state.question || stateNode.props.client.question;
  479. let ind = 0;
  480. while (ind < Question.answers.length) {
  481. let j = 0;
  482. let found = false;
  483. while (j < Question.correctAnswers.length) {
  484. if (Question.answers[ind] == Question.correctAnswers[j]) {
  485. found = true;
  486. break;
  487. }
  488. j++;
  489. }
  490. ind++;
  491. if (found) document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.boxShadow = "unset";
  492. }
  493. }
  494. },
  495. {
  496. name: "Remove Name Limit",
  497. description: "Sets the name limit to 120, which is the actual max name length limit",
  498. run: function () {
  499. document.querySelector('input[class*="nameInput"]').maxLength = 120; /* 120 is the actual limit */
  500. alert("Removed name length limit");
  501. }
  502. },
  503. {
  504. name: "Remove Random Name",
  505. description: "Allows you to put a custom name",
  506. run: function () {
  507. getStateNode().setState({ isRandom: false, client: { name: "" } });
  508. document.querySelector('[class*="nameInput"]')?.focus?.();
  509. }
  510. },
  511. {
  512. name: "Sell Duplicate Blooks",
  513. description: "Sell all duplicate blooks leaving you with 1 each",
  514. run: async function () {
  515. if (window.location.pathname.startsWith("/blooks")) {
  516. if (confirm(`Are you sure you want to sell your dupes? (Legendaries and rarer will not be sold)`)) {
  517. let stateNode = getStateNode();
  518. let now = Date.now(), results = "";
  519. for (const blook in stateNode.state.blookData) if (stateNode.state.blookData[blook] > 1) {
  520. stateNode.setState({ blook, numToSell: stateNode.state.blookData[blook] - 1 });
  521. if (!["Uncommon", "Rare", "Epic"].includes(document.querySelector("[class*='highlightedRarity']").innerText.trim())) continue;
  522. results += ` ${blook} ${stateNode.state.blookData[blook] - 1}\n`;
  523. await stateNode.sellBlook({ preventDefault: () => { } }, true);
  524. }
  525. alert(`(${Date.now() - now}ms) Results:\n${results.trim()}`);
  526. }
  527. } else alert("This can only be ran in the Blooks page.");
  528. }
  529. },
  530. ],
  531. },
  532. voyage: {
  533. name: "Pirate's Voyage",
  534. img: "",
  535. cheats: [
  536. {
  537. name: "Heist ESP",
  538. description: "Shows you what's under each chest during a heist",
  539. type: "toggle",
  540. enabled: false,
  541. data: null,
  542. imgs: null,
  543. run: function () {
  544. if (!this.enabled) {
  545. this.enabled = true;
  546. this.data = setInterval(() => {
  547. const stateNode = getStateNode();
  548. if (stateNode.state.stage != "heist") return;
  549. if (this.imgs == null) this.imgs = Array.prototype.map.call(Array.prototype.slice.call(document.querySelector("[class*=prizesList]").children, 1, 4), (x) => x.querySelector("img").src);
  550. const esp = Object.values(document.querySelector("[class*=modal]"))[0].return.memoizedState.memoizedState;
  551. for (const e of document.querySelectorAll("[class*=boxContent] > div")) e.remove();
  552. const open = Object.values(document.querySelector("[class*=modal]"))[0].return.memoizedState.next.next.memoizedState;
  553. Array.prototype.forEach.call(document.querySelector("[class*=chestsWrapper]").children, (container, i) => {
  554. const box = container.firstChild.firstChild;
  555. if (open.includes(i)) return box.style.opacity = "";
  556. box.style.opacity = "0.5";
  557. let d = document.createElement("div");
  558. d.innerHTML = "<img src='" + this.imgs[2 - esp[i]] + "' style='max-width: 75%; max-height: 75%'></img>";
  559. d.className = "chestESP";
  560. d.style.position = "absolute";
  561. d.style.inset = "0";
  562. d.style.display = "grid";
  563. d.style.placeItems = "center";
  564. d.style.pointerEvents = "none"
  565. container.onclick = () => {
  566. d.remove();
  567. box.style.opacity = "";
  568. };
  569. container.firstChild.prepend(d);
  570. });
  571. }, 50);
  572. } else {
  573. this.enabled = false;
  574. clearInterval(this.data);
  575. this.data = null;
  576. }
  577. }
  578. },
  579. {
  580. name: "Max Levels",
  581. description: "Maxes out all islands and your boat",
  582. run: function () {
  583. let stateNode = getStateNode();
  584. stateNode.setState({ islandLevels: new Array(stateNode.state.islandLevels.length).fill(5) }, stateNode.updateBoatLevel);
  585. }
  586. },
  587. {
  588. name: "Set Doubloons",
  589. description: "Sets Doubloons",
  590. inputs: [{
  591. name: "Amount",
  592. type: "number"
  593. }],
  594. run: function (doubloons) {
  595. let stateNode = getStateNode();
  596. stateNode.setState({ doubloons });
  597. stateNode.props.liveGameController.setVal({
  598. path: `c/${stateNode.props.client.name}/d`,
  599. val: doubloons
  600. });
  601. }
  602. },
  603. {
  604. name: "Start Heist",
  605. description: "Starts a heist on someone",
  606. inputs: [{
  607. name: "Player",
  608. type: "options",
  609. options: () => {
  610. let stateNode = getStateNode();
  611. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  612. }
  613. }],
  614. run: function (target) {
  615. let stateNode = getStateNode();
  616. stateNode.props.liveGameController.getDatabaseVal("c", function (val) {
  617. if (val?.[target]) stateNode.setState({
  618. stage: "heist",
  619. heistInfo: { name: target, blook: val[target].b },
  620. prizeAmount: Math.max(1000, val[target].d || 0)
  621. });
  622. });
  623. }
  624. },
  625. {
  626. name: "Swap Doubloons",
  627. description: "Swaps Doubloons with someone",
  628. inputs: [{
  629. name: "Player",
  630. type: "options",
  631. options: () => {
  632. let stateNode = getStateNode();
  633. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  634. }
  635. }],
  636. run: async function (target) {
  637. let stateNode = getStateNode();
  638. stateNode.props.liveGameController.getDatabaseVal("c", function (val) {
  639. if (!val?.[target]) return;
  640. stateNode.props.liveGameController.setVal({
  641. path: `c/${stateNode.props.client.name}`,
  642. val: {
  643. b: stateNode.props.client.blook,
  644. d: val[target].d,
  645. tat: `${target}:${val[target].d - stateNode.state.doubloons}`
  646. }
  647. });
  648. stateNode.setState({ doubloons: val[target].d });
  649. });
  650. }
  651. },
  652. {
  653. name: "Take Doubloons",
  654. description: "Takes Doubloons from someone",
  655. inputs: [{
  656. name: "Player",
  657. type: "options",
  658. options: () => {
  659. let stateNode = getStateNode();
  660. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  661. }
  662. }],
  663. run: async function (target) {
  664. let stateNode = getStateNode();
  665. stateNode.props.liveGameController.getDatabaseVal("c", function (val) {
  666. if (!val?.[target]) return;
  667. stateNode.props.liveGameController.setVal({
  668. path: `c/${stateNode.props.client.name}`,
  669. val: {
  670. b: stateNode.props.client.blook,
  671. d: stateNode.state.doubloons + val[target].d,
  672. tat: `${target}:${val[target].d}`
  673. }
  674. });
  675. stateNode.setState({ doubloons: stateNode.state.doubloons + val[target].d });
  676. });
  677. }
  678. }
  679. ],
  680. },
  681. brawl: {
  682. name: "Monster Brawl",
  683. img: "https://media.blooket.com/image/upload/v1655233787/Media/survivor/xp/Blue_xp_2.svg",
  684. cheats: [
  685. {
  686. name: "Double Enemy XP",
  687. description: "Doubles enemy XP drop value",
  688. run: function () {
  689. const colliders = getStateNode().game.current.config.sceneConfig.physics.world.colliders._active.filter(x => x.callbackContext?.toString?.()?.includes?.('dmgCd'));
  690. for (let i = 0; i < colliders.length; i++) {
  691. const enemies = colliders[i].object2;
  692. let _start = enemies.classType.prototype.start;
  693. enemies.classType.prototype.start = function () { _start.apply(this, arguments); this.val *= 2; };
  694. enemies.children.entries.forEach(e => e.val *= 2);
  695. }
  696. }
  697. },
  698. {
  699. name: "Half Enemy Speed",
  700. description: "Makes enemies move 2x slower",
  701. run: function () {
  702. const colliders = getStateNode().game.current.config.sceneConfig.physics.world.colliders._active.filter(x => x.callbackContext?.toString?.()?.includes?.('dmgCd'));
  703. for (let i = 0; i < colliders.length; i++) {
  704. const enemies = colliders[i].object2;
  705. let _start = enemies.classType.prototype.start;
  706. enemies.classType.prototype.start = function () { _start.apply(this, arguments); this.speed *= 0.5; };
  707. enemies.children.entries.forEach(e => e.speed *= 0.5);
  708. }
  709. }
  710. },
  711. {
  712. name: "Instant Kill",
  713. description: "Sets all enemies health to 1",
  714. run: function () {
  715. const colliders = getStateNode().game.current.config.sceneConfig.physics.world.colliders._active.filter(x => x.callbackContext?.toString?.()?.includes?.('dmgCd'));
  716. for (let i = 0; i < colliders.length; i++) {
  717. const enemies = colliders[i].object2;
  718. let _start = enemies.classType.prototype.start;
  719. enemies.classType.prototype.start = function () { _start.apply(this, arguments); this.hp = 1; };
  720. enemies.children.entries.forEach(e => e.hp = 1);
  721. }
  722. }
  723. },
  724. {
  725. name: "Invincibility",
  726. description: "Makes you invincible",
  727. run: function () {
  728. for (const collider of getStateNode().game.current.config.sceneConfig.physics.world.colliders._active.filter(x => x.callbackContext?.toString().includes('invulnerableTime') || x.callbackContext?.toString().includes('dmgCd'))) collider.collideCallback = () => { };
  729. }
  730. },
  731. {
  732. name: "Kill Enemies",
  733. description: "Kills all current enemies",
  734. run: function () {
  735. getStateNode().game.current.config.sceneConfig.physics.world.bodies.entries.forEach(x => x?.gameObject?.receiveDamage?.(x.gameObject.hp, 1));
  736. }
  737. },
  738. {
  739. name: "Magnet",
  740. description: "Pulls all xp towards you",
  741. run: function () {
  742. getStateNode().game.current.config.sceneConfig.physics.world.colliders._active.find(x => x.collideCallback?.toString().includes('magnetTime')).collideCallback({ active: true }, { active: true, setActive() { }, setVisible() { } });
  743. }
  744. },
  745. {
  746. name: "Max Current Abilities",
  747. description: "Maxes out all your current abilities",
  748. run: function () {
  749. const stateNode = getStateNode();
  750. for (const [ability, level] of Object.entries(stateNode.state.abilities)) for (let i = 0; i < (10 - level); i++) stateNode.game.current.config.sceneConfig.game.events.emit("level up", ability, stateNode.state.abilities[ability]++);
  751. stateNode.setState({
  752. level: stateNode.game.current.config.sceneConfig.level = [1, 3, 5, 10, 15, 25, 35].sort((a, b) => Math.abs(a - stateNode.state.level) - Math.abs(b - stateNode.state.level))[0] - 1
  753. });
  754. }
  755. },
  756. {
  757. name: "Next Level",
  758. description: "Skips to the next level",
  759. run: function () {
  760. let stateNode = getStateNode();
  761. let { object1: player, object2: xp } = stateNode.game.current.config.sceneConfig.physics.world.colliders._active.find(x => x.collideCallback?.toString().includes('emit("xp'));
  762. xp.get().spawn(player.x, player.y, ((e) => 1 === e ? 1 : e < 5 ? 5 : e < 10 ? 10 : e < 20 ? 20 : e < 30 ? 30 : e < 40 ? 40 : e < 50 ? 50 : 100)(stateNode.state.level) - stateNode.xp);
  763. }
  764. },
  765. {
  766. name: "Remove Obstacles",
  767. description: "Removes all rocks and obstacles",
  768. run: function () {
  769. getStateNode().game.current.config.sceneConfig.physics.world.bodies.entries.forEach(body => { try { if (body.gameObject.frame.texture.key.includes("obstacle")) body.gameObject.destroy(); } catch { } });
  770. }
  771. },
  772. {
  773. name: "Reset Health",
  774. description: "Resets health and gives invincibility for 3 seconds",
  775. run: function () {
  776. getStateNode().game.current.events._events.respawn.fn();
  777. }
  778. }
  779. ],
  780. },
  781. cafe: {
  782. name: "Caf\xe9",
  783. img: "https://media.blooket.com/image/upload/v1655161189/Media/survivor/Pizza_lvl1.svg",
  784. style: { transform: "rotate(22.5deg)" },
  785. cheats: [
  786. {
  787. name: "Max Items",
  788. description: "Maxes out items in the shop (Only usable in the shop)",
  789. run: function () {
  790. if (window.location.pathname !== "/cafe/shop") alert("This can only be run in the shop");
  791. else {
  792. const stateNode = getStateNode();
  793. stateNode.setState({ items: Object.keys(stateNode.state.items).reduce((obj, item) => (obj[item] = 5, obj), {}) });
  794. }
  795. }
  796. },
  797. {
  798. name: "Remove Customers",
  799. description: "Skips the current customers (Not usable in the shop)",
  800. run: function () {
  801. const stateNode = getStateNode();
  802. stateNode.state.customers.forEach((customer, i) => window.setTimeout(() => customer.blook && stateNode.removeCustomer(i, true), i * 250));
  803. }
  804. },
  805. {
  806. name: "Reset Abilities",
  807. description: "Resets used abilities in shop (Only usable in the shop)",
  808. run: function () {
  809. if (window.location.pathname !== "/cafe/shop") alert("This can only be run in the shop");
  810. else {
  811. const stateNode = getStateNode();
  812. stateNode.setState({ abilities: Object.keys(stateNode.state.abilities).reduce((obj, item) => (obj[item] = 5, obj), {}) });
  813. }
  814. }
  815. },
  816. {
  817. name: "Set Cash",
  818. description: "Sets cafe cash",
  819. inputs: [{
  820. name: "Amount",
  821. type: "number"
  822. }],
  823. run: function (cafeCash) {
  824. let stateNode = getStateNode();
  825. stateNode.setState({ cafeCash });
  826. stateNode.props.liveGameController.setVal({
  827. path: `c/${stateNode.props.client.name}/ca`,
  828. val: cafeCash
  829. });
  830. }
  831. },
  832. {
  833. name: "Stock Food",
  834. description: "Stocks all food to 99 (Not usable in the shop)",
  835. run: function () {
  836. if (window.location.pathname !== "/cafe") alert("This can't be run in the shop");
  837. else {
  838. const stateNode = getStateNode();
  839. stateNode.setState({ foods: stateNode.state.foods.map(e => ({ ...e, stock: 99, level: 5 })) });
  840. }
  841. }
  842. }
  843. ],
  844. },
  845. crypto: {
  846. name: "Crypto Hack",
  847. img: "https://media.blooket.com/image/upload/v1661496293/Media/uiTest/CryptoIcon.svg",
  848. cheats: [
  849. {
  850. name: "Choice ESP",
  851. description: "Shows what each choice will give you",
  852. type: "toggle",
  853. enabled: false,
  854. data: null,
  855. run: function () {
  856. if (!this.enabled) {
  857. this.enabled = true;
  858. this.data = setInterval(() => {
  859. let chest = document.querySelector('[class*=feedbackContainer]');
  860. if (chest.children.length <= 4) {
  861. let choice = document.createElement('div')
  862. choice.style.color = "white";
  863. choice.style.fontFamily = "Inconsolata,Helvetica,monospace,sans-serif";
  864. choice.style.fontSize = "2em";
  865. choice.style.display = "flex";
  866. choice.style.justifyContent = "center";
  867. choice.style.marginTop = "675px";
  868. choice.innerText = getStateNode().state.choices[0].text;
  869. chest.append(choice);
  870. }
  871. }, 50);
  872. } else {
  873. this.enabled = false;
  874. clearInterval(this.data);
  875. this.data = null;
  876. }
  877. }
  878. },
  879. {
  880. name: "Password ESP",
  881. description: "Highlights the correct password",
  882. type: "toggle",
  883. enabled: false,
  884. data: null,
  885. run: function () {
  886. if (!this.enabled) {
  887. this.enabled = true;
  888. this.data = setInterval(() => {
  889. let { state } = getStateNode();
  890. if (state.stage == "hack") for (const button of document.querySelector('div[class*=buttonContainer]').children) {
  891. if (button.innerText == state.correctPassword) continue;
  892. button.style.outlineColor = "rgba(255, 64, 64, 0.8)";
  893. button.style.backgroundColor = "rgba(255, 64, 64, 0.8)";
  894. button.style.textShadow = "0 0 1px #f33"
  895. };
  896. }, 50);
  897. } else {
  898. this.enabled = false;
  899. clearInterval(this.data);
  900. this.data = null;
  901. }
  902. }
  903. },
  904. {
  905. name: "Always Triple",
  906. description: "Always get triple crypto",
  907. type: "toggle",
  908. enabled: false,
  909. data: null,
  910. run: function () {
  911. if (!this.enabled) {
  912. this.enabled = true;
  913. this.data = setInterval(state => getStateNode().setState(state), 25, { choices: [{ type: "mult", val: 3, rate: 0.075, blook: "Brainy Bot", text: "Triple Crypto" }] });
  914. } else {
  915. this.enabled = false;
  916. clearInterval(this.data);
  917. this.data = null;
  918. }
  919. }
  920. },
  921. {
  922. name: "Auto Guess",
  923. description: "Automatically guess the correct password",
  924. type: "toggle",
  925. enabled: false,
  926. data: null,
  927. run: function () {
  928. if (!this.enabled) {
  929. this.enabled = true;
  930. this.data = setInterval(() => {
  931. let { state } = getStateNode();
  932. if (state.stage == "hack") for (const button of document.querySelector('div[class*=buttonContainer]').children) button.innerText == state.correctPassword && button.click();
  933. }, 50);
  934. } else {
  935. this.enabled = false;
  936. clearInterval(this.data);
  937. this.data = null;
  938. }
  939. }
  940. },
  941. {
  942. name: "Remove Hack",
  943. description: "Removes an attacking hack",
  944. run: function () {
  945. getStateNode().setState({ hack: "" });
  946. }
  947. },
  948. {
  949. name: "Set Crypto",
  950. description: "Sets crypto",
  951. inputs: [{
  952. name: "Amount",
  953. type: "number"
  954. }],
  955. run: function (amount) {
  956. let stateNode = getStateNode();
  957. stateNode.setState({ crypto: amount, crypto2: amount });
  958. stateNode.props.liveGameController.setVal({
  959. path: `c/${stateNode.props.client.name}/cr`,
  960. val: amount
  961. });
  962. }
  963. },
  964. {
  965. name: "Set Password",
  966. description: "Sets hacking password",
  967. inputs: [{
  968. name: "Custom Password",
  969. type: "string"
  970. }],
  971. run: function (password) {
  972. let stateNode = getStateNode();
  973. stateNode.setState({ password });
  974. stateNode.props.liveGameController.setVal({
  975. path: `c/${stateNode.props.client.name}/p`,
  976. val: password
  977. });
  978. }
  979. },
  980. {
  981. name: "Steal Player's Crypto",
  982. description: "Steals all of someone's crypto",
  983. inputs: [{
  984. name: "Player",
  985. type: "options",
  986. options: () => {
  987. let stateNode = getStateNode();
  988. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  989. }
  990. }],
  991. run: function (target) {
  992. let stateNode = getStateNode();
  993. stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
  994. let player;
  995. if (players && (player = Object.entries(players).find((x) => x[0].toLowerCase() == target.toLowerCase()))) {
  996. const cr = player[1].cr;
  997. stateNode.setState({
  998. crypto: stateNode.state.crypto + cr,
  999. crypto2: stateNode.state.crypto + cr
  1000. });
  1001. stateNode.props.liveGameController.setVal({
  1002. path: "c/" + stateNode.props.client.name,
  1003. val: {
  1004. b: stateNode.props.client.blook,
  1005. p: stateNode.state.password,
  1006. cr: stateNode.state.crypto + cr,
  1007. tat: player[0] + ":" + cr
  1008. }
  1009. });
  1010. }
  1011. })
  1012. }
  1013. }
  1014. ],
  1015. },
  1016. defense: {
  1017. name: "Tower Defense",
  1018. img: "https://media.blooket.com/image/upload/v1657235025/Media/survivor/Laser_Lvl1.svg",
  1019. cheats: [
  1020. {
  1021. name: "Earthquake",
  1022. description: "Shuffles around towers",
  1023. run: function () {
  1024. let stateNode = getStateNode();
  1025. stateNode.setState({
  1026. eventName: "Earthquake",
  1027. event: {
  1028. short: "e",
  1029. color: "#805500",
  1030. icon: "fas fa-mountain",
  1031. desc: "All of your towers get mixed up",
  1032. rate: .02
  1033. },
  1034. buyTowerName: "",
  1035. buyTower: {}
  1036. }, () => stateNode.eventTimeout = setTimeout(() => stateNode.setState({ event: {}, eventName: "" }), 6e3));
  1037. stateNode.tiles.forEach(row => row.forEach((col, i) => col == 3 && (row[i] = 0)));
  1038. let tiles = [];
  1039. for (let y = 0; y < stateNode.tiles.length; y++)
  1040. for (let x = 0; x < stateNode.tiles[y].length; x++)
  1041. if (stateNode.tiles[y][x] == 0) tiles.push({ x, y });
  1042. tiles.sort(() => Math.random() - Math.random());
  1043. stateNode.towers.forEach(tower => {
  1044. let { x, y } = tiles.pop();
  1045. tower.move(x, y, stateNode.tileSize);
  1046. stateNode.tiles[y][x] = 3;
  1047. });
  1048. }
  1049. },
  1050. {
  1051. name: "Max Tower Stats",
  1052. description: "Makes all placed towers overpowered",
  1053. run: function () {
  1054. getStateNode().towers.forEach(tower => {
  1055. tower.range = 100;
  1056. tower.fullCd = tower.cd = 0;
  1057. tower.damage = 1e6;
  1058. });
  1059. }
  1060. },
  1061. {
  1062. name: "Remove Ducks",
  1063. description: "Removes ducks",
  1064. run: function () {
  1065. let { ducks, tiles } = getStateNode();
  1066. ducks.forEach(x => (tiles[x.y][x.x] = 0));
  1067. ducks.length = 0;
  1068. }
  1069. },
  1070. {
  1071. name: "Remove Enemies",
  1072. description: "Removes all the enemies",
  1073. run: function () {
  1074. let stateNode = getStateNode();
  1075. stateNode.enemies = stateNode.futureEnemies = [];
  1076. }
  1077. },
  1078. {
  1079. name: "Remove Obstacles",
  1080. description: "Lets you place towers anywhere",
  1081. run: function () {
  1082. let stateNode = getStateNode();
  1083. stateNode.tiles = stateNode.tiles.map(row => row.fill(0));
  1084. }
  1085. },
  1086. {
  1087. name: "Set Damage",
  1088. description: "Sets damage",
  1089. inputs: [{
  1090. name: "Damage",
  1091. type: "number"
  1092. }],
  1093. run: function (dmg) {
  1094. getStateNode().dmg = dmg;
  1095. }
  1096. },
  1097. {
  1098. name: "Set Round",
  1099. description: "Sets the current round",
  1100. inputs: [{
  1101. name: "Round",
  1102. type: "number"
  1103. }],
  1104. run: function (round) {
  1105. getStateNode().setState({ round });
  1106. }
  1107. },
  1108. {
  1109. name: "Set Tokens",
  1110. description: "Sets the amount of tokens you have",
  1111. inputs: [{
  1112. name: "Tokens",
  1113. type: "number"
  1114. }],
  1115. run: function (tokens) {
  1116. getStateNode().setState({ tokens });
  1117. }
  1118. }
  1119. ],
  1120. },
  1121. defense2: {
  1122. name: "Tower Defense 2",
  1123. img: "https://media.blooket.com/image/upload/v1593095354/Media/defense/missile.svg",
  1124. style: { transform: "rotate(45deg)" },
  1125. cheats: [
  1126. {
  1127. name: "Max Tower Stats",
  1128. description: "Makes all placed towers overpowered",
  1129. run: function () {
  1130. getStateNode().state.towers.forEach(tower => {
  1131. tower.stats.dmg = 1e6;
  1132. tower.stats.fireRate = 50;
  1133. tower.stats.ghostDetect = true;
  1134. tower.stats.maxTargets = 1e6;
  1135. tower.stats.numProjectiles &&= 100;
  1136. tower.stats.range = 100;
  1137. if (tower.stats.auraBuffs) for (const buff in tower.stats.auraBuffs) tower.stats.auraBuffs[buff] *= 100;
  1138. });
  1139. }
  1140. },
  1141. {
  1142. name: "Kill Enemies",
  1143. description: "Kills all the enemies",
  1144. run: function () {
  1145. let stateNode = getStateNode();
  1146. stateNode.game.current.config.sceneConfig.enemyQueue.length = 0;
  1147. stateNode.game.current.config.sceneConfig.physics.world.bodies.entries.forEach(x => x?.gameObject?.receiveDamage?.(x.gameObject.hp, 1));
  1148. }
  1149. },
  1150. {
  1151. name: "Set Coins",
  1152. description: "Sets coins",
  1153. inputs: [{
  1154. name: "Coins",
  1155. type: "number"
  1156. }],
  1157. run: function (coins) {
  1158. getStateNode().setState({ coins });
  1159. }
  1160. },
  1161. {
  1162. name: "Set Health",
  1163. description: "Sets the amount of health you have",
  1164. inputs: [{
  1165. name: "Health",
  1166. type: "number"
  1167. }],
  1168. run: function (health) {
  1169. getStateNode().setState({ health });
  1170. }
  1171. },
  1172. {
  1173. name: "Set Round",
  1174. description: "Sets the current round",
  1175. inputs: [{
  1176. name: "Round",
  1177. type: "number"
  1178. }],
  1179. run: function (round) {
  1180. getStateNode().setState({ round });
  1181. }
  1182. },
  1183. ],
  1184. },
  1185. dinos: {
  1186. name: "Deceptive Dinos",
  1187. img: "https://media.blooket.com/image/upload/v1655161325/Media/survivor/Dog.svg",
  1188. style: { transform: "rotate(-22.5deg)" },
  1189. cheats: [
  1190. {
  1191. name: "Auto Choose",
  1192. description: "Automatically choose the best fossil when excavating",
  1193. type: "toggle",
  1194. enabled: false,
  1195. data: null,
  1196. rand(e, t) {
  1197. const s = [];
  1198. while (s.length < t) {
  1199. const i = Math.random();
  1200. let r = 0, g = null;
  1201. for (let o = 0; o < e.length; o++) {
  1202. r += e[o].rate;
  1203. if (r >= i) {
  1204. g = e[o];
  1205. break;
  1206. }
  1207. }
  1208. g && !s.includes(g) && s.push(g)
  1209. }
  1210. return s;
  1211. },
  1212. run: function () {
  1213. if (!this.enabled) {
  1214. this.enabled = true;
  1215. this.data = setInterval(() => {
  1216. try {
  1217. let stateNode = getStateNode();
  1218. if (stateNode.state.stage === "excavate") {
  1219. stateNode.state.choices.length || (stateNode.state.choices = this.rand([{ type: "fossil", val: 10, rate: .1, blook: "Amber" }, { type: "fossil", val: 25, rate: .1, blook: "Dino Egg" }, { type: "fossil", val: 50, rate: .175, blook: "Dino Fossil" }, { type: "fossil", val: 75, rate: .175, blook: "Stegosaurus" }, { type: "fossil", val: 100, rate: .15, blook: "Velociraptor" }, { type: "fossil", val: 125, rate: .125, blook: "Brontosaurus" }, { type: "fossil", val: 250, rate: .075, blook: "Triceratops" }, { type: "fossil", val: 500, rate: .025, blook: "Tyrannosaurus Rex" }, { type: "mult", val: 1.5, rate: .05 }, { type: "mult", val: 2, rate: .025 }], 3));
  1220. let max = 0, index = -1;
  1221. for (let i = 0; i < stateNode.state.choices.length; i++) {
  1222. const { type, val } = stateNode.state.choices[i];
  1223. const value = (type == "fossil" ? stateNode.state.fossils + val * stateNode.state.fossilMult : stateNode.state.fossils * val) || 0;
  1224. if (value <= max && type != "mult") continue;
  1225. max = value, index = i + 1;
  1226. }
  1227. document.querySelector('div[class*=rockRow] > div[role="button"]:nth-child(' + index + ')').click();
  1228. }
  1229. } catch { }
  1230. }, 50);
  1231. } else {
  1232. this.enabled = false;
  1233. clearInterval(this.data);
  1234. this.data = null;
  1235. }
  1236. }
  1237. },
  1238. {
  1239. name: "Rock ESP",
  1240. description: "Shows what is under the rocks",
  1241. type: "toggle",
  1242. enabled: false,
  1243. data: null,
  1244. run: (() => {
  1245. function rand(e, t) {
  1246. const s = [];
  1247. while (s.length < t) {
  1248. const i = Math.random();
  1249. let r = 0;
  1250. let g;
  1251. for (let o = 0; o < e.length; o++) {
  1252. r += e[o].rate;
  1253. if (r >= i) {
  1254. g = e[o];
  1255. break;
  1256. }
  1257. }
  1258. if (g && !s.includes(g)) s.push(g);
  1259. }
  1260. return s;
  1261. };
  1262. const exps = ["⁰", "¹", "²", "³", "⁴", "⁵", "⁶", "⁷", "⁸", "⁹"];
  1263. const getExpAscii = (num) => {
  1264. let res = "";
  1265. while (num > 0) {
  1266. res = exps[num % 10] + res;;
  1267. num = ~~(num / 10);
  1268. }
  1269. return res;
  1270. };
  1271. function shortNum(value) {
  1272. let newValue = value.toString();
  1273. if (value >= 1000) {
  1274. const suffixes = ["", "K", "M", "B", "T"];
  1275. const suffixNum = Math.floor(Math.floor((Math.log(value) / Math.log(10)).toPrecision(14)) / 3);
  1276. if (suffixNum < suffixes.length) {
  1277. let shortValue = "";
  1278. for (let precision = 3; precision >= 1; precision--) {
  1279. shortValue = parseFloat((suffixNum != 0 ? value / Math.pow(1000, suffixNum) : value).toPrecision(precision)).toString();
  1280. const dotLessShortValue = shortValue.replace(/[^a-zA-Z 0-9]+/g, "");
  1281. if (dotLessShortValue.length <= 3) break;
  1282. }
  1283. if (Number(shortValue) % 1 != 0) shortValue = Number(shortValue).toFixed(1);
  1284. newValue = shortValue + suffixes[suffixNum];
  1285. } else {
  1286. let num = value;
  1287. let exp = 0;
  1288. while (num >= 100) {
  1289. num = Math.floor(num / 10);
  1290. exp += 1;
  1291. }
  1292. newValue = num / 10 + " × 10" + getExpAscii(exp + 1);
  1293. }
  1294. }
  1295. return newValue;
  1296. };
  1297. return function () {
  1298. if (!this.enabled) {
  1299. this.enabled = true;
  1300. this.data = setInterval(() => {
  1301. let stateNode = getStateNode();
  1302. const rocks = document.querySelector('[class*="rockButton"]').parentElement.children;
  1303. if (!Array.prototype.every.call(rocks, element => element.querySelector('div'))) stateNode.setState({
  1304. choices: rand([{ type: "fossil", val: 10, rate: 0.1, blook: "Amber" }, { type: "fossil", val: 25, rate: 0.1, blook: "Dino Egg" }, { type: "fossil", val: 50, rate: 0.175, blook: "Dino Fossil" }, { type: "fossil", val: 75, rate: 0.175, blook: "Stegosaurus" }, { type: "fossil", val: 100, rate: 0.15, blook: "Velociraptor" }, { type: "fossil", val: 125, rate: 0.125, blook: "Brontosaurus" }, { type: "fossil", val: 250, rate: 0.075, blook: "Triceratops" }, { type: "fossil", val: 500, rate: 0.025, blook: "Tyrannosaurus Rex" }, { type: "mult", val: 1.5, rate: 0.05 }, { type: "mult", val: 2, rate: 0.025 }], 3)
  1305. }, () => {
  1306. Array.prototype.forEach.call(rocks, (element, index) => {
  1307. const rock = stateNode.state.choices[index];
  1308. if (element.querySelector('div')) element.querySelector('div').remove();
  1309. const choice = document.createElement("div");
  1310. choice.style.color = "white";
  1311. choice.style.fontFamily = "Macondo";
  1312. choice.style.fontSize = "1em";
  1313. choice.style.display = "flex";
  1314. choice.style.justifyContent = "center";
  1315. choice.style.transform = "translateY(25px)";
  1316. choice.innerText = rock.type === "fossil" ? `+${Math.round(rock.val * stateNode.state.fossilMult) > 99999999 ? shortNum(Math.round(rock.val * stateNode.state.fossilMult)) : Math.round(rock.val * stateNode.state.fossilMult)} Fossils` : `x${rock.val} Fossils Per Excavation`;;
  1317. element.append(choice);
  1318. });
  1319. });
  1320. }, 50);
  1321. } else {
  1322. this.enabled = false;
  1323. clearInterval(this.data);
  1324. this.data = null;
  1325. }
  1326. }
  1327. })()
  1328. },
  1329. {
  1330. name: "Set Fossils",
  1331. description: "Sets the amount of fossils you have",
  1332. inputs: [{
  1333. name: "Fossils",
  1334. type: "number"
  1335. }],
  1336. run: function (fossils) {
  1337. let stateNode = getStateNode();
  1338. stateNode.setState({ fossils });
  1339. stateNode.props.liveGameController.setVal({
  1340. path: `c/${stateNode.props.client.name}/f`,
  1341. val: fossils
  1342. });
  1343. }
  1344. },
  1345. {
  1346. name: "Set Multiplier",
  1347. description: "Sets fossil multiplier",
  1348. inputs: [{
  1349. name: "Multiplier",
  1350. type: "number"
  1351. }],
  1352. run: function (fossilMult) {
  1353. let stateNode = getStateNode();
  1354. stateNode.setState({ fossilMult });
  1355. }
  1356. },
  1357. {
  1358. name: "Stop Cheating",
  1359. description: "Undoes cheating so that you can't be caught",
  1360. run: function () {
  1361. let stateNode = getStateNode();
  1362. stateNode.setState({ isCheating: false });
  1363. stateNode.props.liveGameController.setVal({
  1364. path: `c/${stateNode.props.client.name}/ic`,
  1365. val: false
  1366. });
  1367. }
  1368. }
  1369. ],
  1370. },
  1371. doom: {
  1372. name: "Tower of Doom",
  1373. img: "https://media.blooket.com/image/upload/v1657235023/Media/survivor/cards-05.svg",
  1374. cheats: [
  1375. {
  1376. name: "Fill Deck",
  1377. description: "Fills your deck with every maxed out card and artifact (Only works on towers page)",
  1378. run: function () {
  1379. if (window.location.pathname == "/tower/map") {
  1380. const stateNode = getStateNode();
  1381. stateNode.props.tower.artifacts = "Medical Kit|Fury Relic|Survival Guide|Steel Socks|Piggy Bank|Lucky Feather|Coupon|Cheese|Tasty Egg|Training Weights|Mighty Shield|Toxic Waste|Lifeline Totem|Cursed Hourglass|Band-Aid|Elder Coins|Captain's Anchor|Chess Pieces|Pink Hippo|Anorak's Wizard Cap|Dave's Doggo|Anubis' Obelisk|Farm Tractor|Magic Seedling|Just A Bone|Cozy Igloo|King's Crown|Sacred Scroll".split("|");
  1382. stateNode.props.tower.cards = 'Chick,🌽|Chicken,🌽|Cow,🌽|Goat,🌽|Horse,🌽|Pig,🌽|Sheep,🌽|Duck,🌽|Dog,🌽|Cat,🐾|Rabbit,🐾|Goldfish,🐾|Hamster,🐾|Turtle,🐾|Kitten,🐾|Puppy,🐾|Bear,🌲|Moose,🌲|Fox,🌲|Raccoon,🌲|Squirrel,🌲|Owl,🌲|Hedgehog,🌲|Baby Penguin,❄️|Penguin,❄️|Arctic Fox,❄️|Snowy Owl,❄️|Polar Bear,❄️|Arctic Hare,❄️|Seal,❄️|Walrus,❄️|Tiger,🌴|Panther,🌴|Cockatoo,🌴|Orangutan,🌴|Anaconda,🌴|Macaw,🌴|Jaguar,🌴|Capuchin,🌴|Toucan,🌴|Parrot,🌴|Elf,⚔️|Witch,⚔️|Wizard,⚔️|Fairy,⚔️|Slime Monster,⚔️|Jester,⚔️|Dragon,⚔️|Unicorn,⚔️|Queen,⚔️|King,⚔️|Snow Globe,☃️|Holiday Gift,☃️|Hot Chocolate,☃️|Gingerbread Man,☃️|Gingerbread House,☃️|Holiday Wreath,☃️|Snowman,☃️|Santa Claus,☃️|Two of Spades,🏰|Eat Me,🏰|Drink Me,🏰|Alice,🏰|Queen of Hearts,🏰|Dormouse,🏰|White Rabbit,🏰|Cheshire Cat,🏰|Caterpillar,🏰|Mad Hatter,🏰|King of Hearts,🏰'.split("|").map(x => {
  1383. const [blook, c] = x.split(",");
  1384. return { strength: 20, charisma: 20, wisdom: 20, class: c, blook };
  1385. });
  1386. try { stateNode.props.addTowerNode(); } catch { }
  1387. stateNode.setState({ showDeck: false });
  1388. } else alert("You need to be on the map to run this cheat!");
  1389. }
  1390. },
  1391. {
  1392. name: "Max Cards",
  1393. description: "Maxes out all the cards in your deck",
  1394. run: function () {
  1395. if (window.location.pathname == "/tower/map") {
  1396. const stateNode = getStateNode();
  1397. stateNode.props.tower.cards.forEach(card => {
  1398. card.strength = 20;
  1399. card.charisma = 20;
  1400. card.wisdom = 20;
  1401. });
  1402. try { stateNode.forceUpdate(); } catch { }
  1403. } else alert("You need to be on the map to run this cheat!");
  1404. }
  1405. },
  1406. {
  1407. name: "Max Health",
  1408. description: "Fills the player's health",
  1409. run: function () {
  1410. if (window.location.pathname == "/tower/battle") getStateNode().setState({ myHealth: 100, myLife: 100 });
  1411. else alert("You need to be in battle to run this cheat!");
  1412. }
  1413. },
  1414. {
  1415. name: "Max Card Stats",
  1416. description: "Maxes out player's current card (Only works on attribute select page)",
  1417. run: function () {
  1418. const stateNode = getStateNode();
  1419. if (stateNode.state.phase !== 'select') alert('You must be on the attribute selection page!');
  1420. else stateNode.setState({ myCard: { ...stateNode.state.myCard, strength: 20, charisma: 20, wisdom: 20 } });
  1421. }
  1422. },
  1423. {
  1424. name: "Min Enemy Stats",
  1425. description: "Makes the enemy card stats all 0 (Only works on attribute select page)",
  1426. run: function () {
  1427. const stateNode = getStateNode();
  1428. if (stateNode.state.phase !== 'select') alert('You must be on the attribute selection page!');
  1429. else stateNode.setState({ enemyCard: { ...stateNode.state.enemyCard, strength: 0, charisma: 0, wisdom: 0 } });
  1430. }
  1431. },
  1432. {
  1433. name: "Set Coins",
  1434. description: "Try's to set amount of tower coins you have",
  1435. inputs: [{
  1436. name: "Coins",
  1437. type: "number"
  1438. }],
  1439. run: function (coins) {
  1440. if (window.location.pathname == "/tower/battle") try {
  1441. getStateNode().props.setTowerCoins(coins);
  1442. } catch { }
  1443. else alert("You need to be in battle to run this cheat!");
  1444. }
  1445. }
  1446. ],
  1447. },
  1448. factory: {
  1449. name: "Factory",
  1450. img: "https://media.blooket.com/image/upload/v1661496293/Media/uiTest/Factory_Upgrades.svg",
  1451. cheats: [
  1452. {
  1453. name: "Choose Blook",
  1454. description: "Gives you a blook",
  1455. inputs: [{
  1456. name: "Blook",
  1457. type: "options",
  1458. options: [{ name: "Chick", color: "#ffcd05", class: "\uD83C\uDF3D", rarity: "Common", cash: [3, 7, 65, 400, 2500], time: [1, 1, 1, 1, 1], price: [300, 3e3, 3e4, 2e5] }, { name: "Chicken", color: "#ed1c24", class: "\uD83C\uDF3D", rarity: "Common", cash: [10, 40, 200, 1400, 1e4], time: [5, 4, 3, 2, 1], price: [570, 4e3, 5e4, 8e5] }, { name: "Cow", color: "#58595b", class: "\uD83C\uDF3D", rarity: "Common", cash: [25, 75, 1500, 25e3, 25e4], time: [15, 10, 10, 10, 5], price: [500, 9500, 16e4, 4e6] }, { name: "Duck", color: "#4ab96d", class: "\uD83C\uDF3D", rarity: "Common", cash: [4, 24, 200, 3e3, 4e4], time: [3, 3, 3, 3, 3], price: [450, 4200, 7e4, 11e5] }, { name: "Goat", color: "#c59a74", class: "\uD83C\uDF3D", rarity: "Common", cash: [5, 28, 200, 1300, 12e3], time: [3, 3, 2, 2, 2], price: [500, 6400, 45e3, 5e5] }, { name: "Horse", color: "#995b3c", class: "\uD83C\uDF3D", rarity: "Common", cash: [5, 20, 270, 1800, 15e3], time: [2, 2, 2, 2, 2], price: [550, 8200, 65e3, 6e5] }, { name: "Pig", color: "#f6a9cb", class: "\uD83C\uDF3D", rarity: "Common", cash: [20, 50, 1300, 8e3, 8e4], time: [7, 7, 7, 7, 5], price: [400, 11e3, 8e4, 13e5] }, { name: "Sheep", color: "#414042", class: "\uD83C\uDF3D", rarity: "Common", cash: [6, 25, 250, 1500, 11e3], time: [3, 3, 3, 2, 2], price: [500, 5e3, 5e4, 43e4] }, { name: "Cat", color: "#f49849", class: "\uD83D\uDC3E", rarity: "Common", cash: [5, 18, 170, 1700, 13e3], time: [2, 2, 2, 2, 2], price: [480, 5500, 6e4, 5e5] }, { name: "Dog", color: "#995b3c", class: "\uD83D\uDC3E", rarity: "Common", cash: [7, 25, 220, 1900, 9e3], time: [3, 3, 2, 2, 1], price: [460, 6600, 7e4, 73e4] }, { name: "Goldfish", color: "#f18221", class: "\uD83D\uDC3E", rarity: "Common", cash: [5, 40, 350, 3500, 35e3], time: [3, 3, 3, 3, 3], price: [750, 7200, 84e3, 95e4] }, { name: "Rabbit", color: "#e7bf9a", class: "\uD83D\uDC3E", rarity: "Common", cash: [3, 18, 185, 800, 7e3], time: [2, 2, 2, 1, 1], price: [500, 5800, 56e3, 55e4] }, { name: "Hamster", color: "#ce9176", class: "\uD83D\uDC3E", rarity: "Common", cash: [10, 45, 450, 4500, 45e3], time: [4, 4, 4, 4, 4], price: [650, 6500, 8e4, 93e4] }, { name: "Turtle", color: "#619a3c", class: "\uD83D\uDC3E", rarity: "Common", cash: [23, 120, 1400, 15e3, 17e4], time: [10, 10, 10, 10, 10], price: [700, 8500, 11e4, 13e5] }, { name: "Puppy", color: "#414042", class: "\uD83D\uDC3E", rarity: "Common", cash: [4, 10, 75, 500, 3e3], time: [1, 1, 1, 1, 1], price: [450, 4e3, 35e3, 25e4] }, { name: "Kitten", color: "#58595b", class: "\uD83D\uDC3E", rarity: "Common", cash: [4, 8, 60, 400, 2e3], time: [1, 1, 1, 1, 1], price: [350, 3500, 26e3, 17e4] }, { name: "Bear", color: "#995b3c", class: "\uD83C\uDF32", rarity: "Common", cash: [12, 70, 550, 4500, 1e5], time: [7, 7, 6, 5, 5], price: [550, 5500, 63e3, 16e5] }, { name: "Moose", color: "#995b3c", class: "\uD83C\uDF32", rarity: "Common", cash: [8, 45, 400, 3500, 26e3], time: [5, 5, 4, 4, 3], price: [520, 6500, 58e3, 7e5] }, { name: "Fox", color: "#f49849", class: "\uD83C\uDF32", rarity: "Common", cash: [7, 15, 80, 550, 3e3], time: [2, 2, 1, 1, 1], price: [400, 4e3, 36e3, 24e4] }, { name: "Raccoon", color: "#6d6e71", class: "\uD83C\uDF32", rarity: "Common", cash: [5, 14, 185, 1900, 19e3], time: [2, 2, 2, 2, 2], price: [400, 5e3, 71e3, 8e5] }, { name: "Squirrel", color: "#d25927", class: "\uD83C\uDF32", rarity: "Common", cash: [3, 10, 65, 470, 2600], time: [1, 1, 1, 1, 1], price: [420, 3600, 32e3, 21e4] }, { name: "Owl", color: "#594a42", class: "\uD83C\uDF32", rarity: "Common", cash: [4, 17, 155, 1500, 15e3], time: [2, 2, 2, 2, 2], price: [500, 4800, 55e3, 58e4] }, { name: "Hedgehog", color: "#3f312b", class: "\uD83C\uDF32", rarity: "Common", cash: [11, 37, 340, 2200, 3e4], time: [5, 4, 3, 2, 2], price: [540, 7e3, 77e3, 12e5] }, { name: "Seal", color: "#7ca1d5", class: "❄️", rarity: "Common", cash: [6, 17, 150, 1200, 13e3], time: [2, 2, 2, 2, 2], price: [480, 4500, 43e3, 52e4] }, { name: "Arctic Fox", color: "#7ca1d5", class: "❄️", rarity: "Common", cash: [5, 18, 180, 850, 8500], time: [2, 2, 2, 1, 1], price: [520, 550, 61e3, 68e4] }, { name: "Snowy Owl", color: "#feda3f", class: "❄️", rarity: "Common", cash: [5, 20, 190, 1900, 16e3], time: [3, 3, 2, 2, 2], price: [370, 5300, 76e3, 62e4] }, { name: "Arctic Hare", color: "#7ca1d5", class: "❄️", rarity: "Common", cash: [6, 19, 85, 900, 7e3], time: [2, 2, 1, 1, 1], price: [540, 5200, 66e3, 55e4] }, { name: "Penguin", color: "#fb8640", class: "❄️", rarity: "Common", cash: [4, 21, 310, 3200, 33e3], time: [3, 3, 3, 3, 3], price: [400, 6500, 76e3, 87e4] }, { name: "Baby Penguin", color: "#414042", class: "❄️", rarity: "Common", cash: [3, 8, 70, 450, 2700], time: [1, 1, 1, 1, 1], price: [420, 3300, 33e3, 23e4] }, { name: "Polar Bear", color: "#7ca1d5", class: "❄️", rarity: "Common", cash: [12, 75, 700, 6500, 85e3], time: [8, 7, 6, 5, 5], price: [630, 7e3, 91e3, 14e5] }, { name: "Walrus", color: "#7d4f33", class: "❄️", rarity: "Common", cash: [11, 46, 420, 3700, 51e3], time: [5, 5, 4, 4, 4], price: [550, 6200, 68e3, 1e6] }, { name: "Tiger", color: "#f18221", class: "\uD83C\uDF34", rarity: "Common", cash: [6, 20, 100, 975, 7500], time: [3, 3, 1, 1, 1], price: [390, 6e3, 7e4, 61e4] }, { name: "Jaguar", color: "#fbb040", class: "\uD83C\uDF34", rarity: "Common", cash: [8, 28, 230, 1600, 17e3], time: [3, 3, 2, 2, 2], price: [390, 6e3, 7e4, 61e4] }, { name: "Toucan", color: "#ffca34", class: "\uD83C\uDF34", rarity: "Common", cash: [9, 20, 175, 625, 3800], time: [2, 2, 2, 1, 1], price: [520, 4800, 42e3, 3e5] }, { name: "Cockatoo", color: "#7ca1d5", class: "\uD83C\uDF34", rarity: "Common", cash: [6, 35, 160, 1700, 18e3], time: [4, 4, 2, 2, 2], price: [500, 5e3, 63e3, 7e5] }, { name: "Macaw", color: "#00aeef", class: "\uD83C\uDF34", rarity: "Common", cash: [3, 8, 85, 850, 8500], time: [1, 1, 1, 1, 1], price: [480, 5400, 62e3, 63e4] }, { name: "Parrot", color: "#ed1c24", class: "\uD83C\uDF34", rarity: "Common", cash: [3, 9, 90, 900, 9e3], time: [1, 1, 1, 1, 1], price: [540, 5700, 65e3, 69e4] }, { name: "Panther", color: "#2f2c38", class: "\uD83C\uDF34", rarity: "Common", cash: [12, 28, 215, 2100, 21e3], time: [5, 3, 2, 2, 2], price: [530, 6500, 76e3, 87e4] }, { name: "Anaconda", color: "#8a9143", class: "\uD83C\uDF34", rarity: "Common", cash: [3, 15, 85, 1500, 7600], time: [1, 2, 1, 2, 1], price: [410, 5100, 58e3, 59e4] }, { name: "Orangutan", color: "#bc6234", class: "\uD83C\uDF34", rarity: "Common", cash: [13, 52, 570, 4300, 7e4], time: [5, 5, 5, 4, 4], price: [600, 7e3, 8e4, 14e5] }, { name: "Capuchin", color: "#e0b0a6", class: "\uD83C\uDF34", rarity: "Common", cash: [4, 14, 160, 780, 8200], time: [2, 2, 2, 1, 1], price: [390, 4700, 57e3, 68e4] }, { name: "Elf", color: "#a7d054", class: "⚔️", rarity: "Uncommon", cash: [5e3, 15e3, 15e4, 15e5, 1e7], time: [1, 1, 1, 1, 1], price: [8e5, 9e6, 11e7, 8e8] }, { name: "Witch", color: "#4ab96d", class: "⚔️", rarity: "Uncommon", cash: [18e3, 6e4, 4e4, 4e6, 35e6], time: [3, 3, 2, 2, 2], price: [11e5, 12e6, 15e7, 14e8] }, { name: "Wizard", color: "#5a459c", class: "⚔️", rarity: "Uncommon", cash: [19500, 65e3, 44e4, 46e5, 4e6], time: [3, 3, 2, 2, 2], price: [13e5, 135e5, 16e7, 16e8] }, { name: "Fairy", color: "#df6d9c", class: "⚔️", rarity: "Uncommon", cash: [18500, 6e4, 62e4, 44e5, 38e6], time: [3, 3, 3, 2, 2], price: [12e5, 125e5, 15e6, 15e8] }, { name: "Slime Monster", color: "#2fa04a", class: "⚔️", rarity: "Uncommon", cash: [35e3, 14e4, 1e6, 11e6, 11e7], time: [5, 5, 4, 4, 4], price: [16e5, 15e6, 2e8, 23e8] }, { name: "Jester", color: "#be1e2d", class: "⚔️", rarity: "Rare", cash: [25e3, 1e5, 68e4, 65e5, 32e6], time: [3, 3, 2, 2, 1], price: [2e6, 21e6, 23e7, 26e8] }, { name: "Dragon", color: "#2fa04a", class: "⚔️", rarity: "Rare", cash: [36e3, 15e4, 15e5, 15e6, 15e7], time: [4, 4, 4, 4, 4], price: [23e5, 24e6, 27e7, 3e9] }, { name: "Unicorn", color: "#f6afce", class: "⚔️", rarity: "Epic", cash: [24e3, 15e4, 14e5, 7e6, 75e6], time: [2, 2, 2, 1, 1], price: [45e5, 45e6, 55e7, 65e8] }, { name: "Queen", color: "#9e1f63", class: "⚔️", rarity: "Rare", cash: [24e3, 95e3, 95e4, 97e5, 95e6], time: [3, 3, 3, 3, 3], price: [19e5, 2e7, 23e7, 25e8] }, { name: "King", color: "#ee2640", class: "⚔️", rarity: "Legendary", cash: [75e3, 4e5, 6e6, 9e7, 125e7], time: [5, 5, 5, 5, 5], price: [6e6, 95e6, 16e8, 25e9] }, { name: "Two of Spades", color: "#414042", class: "\uD83C\uDFF0", rarity: "Uncommon", cash: [4500, 14e3, 14e4, 14e5, 9e6], time: [1, 1, 1, 1, 1], price: [77e4, 83e5, 98e6, 71e7] }, { name: "Eat Me", color: "#d58c55", class: "\uD83C\uDFF0", rarity: "Uncommon", cash: [13e3, 45e3, 45e4, 45e5, 5e7], time: [2, 2, 2, 2, 2], price: [13e5, 14e6, 16e7, 2e9] }, { name: "Drink Me", color: "#dd7399", class: "\uD83C\uDFF0", rarity: "Uncommon", cash: [12e3, 4e4, 4e5, 4e6, 45e6], time: [2, 2, 2, 2, 2], price: [12e5, 12e6, 14e7, 18e8] }, { name: "Alice", color: "#4cc9f5", class: "\uD83C\uDFF0", rarity: "Uncommon", cash: [13e3, 42e3, 21e4, 21e5, 23e6], time: [2, 2, 1, 1, 1], price: [12e5, 13e6, 15e7, 19e8] }, { name: "Queen of Hearts", color: "#d62027", class: "\uD83C\uDFF0", rarity: "Uncommon", cash: [23e3, 87e3, 62e4, 75e5, 9e7], time: [4, 4, 3, 3, 3], price: [13e5, 13e6, 18e7, 24e8] }, { name: "Dormouse", color: "#89d6f8", class: "\uD83C\uDFF0", rarity: "Rare", cash: [17e3, 68e3, 7e5, 35e5, 35e6], time: [2, 2, 1, 1, 1], price: [2e6, 22e6, 25e7, 28e8] }, { name: "White Rabbit", color: "#ffcd05", class: "\uD83C\uDFF0", rarity: "Rare", cash: [26e3, 105e3, 11e6, 77e5, 72e6], time: [3, 3, 3, 2, 2], price: [2e6, 23e6, 28e7, 29e8] }, { name: "Cheshire Cat", color: "#dd7399", class: "\uD83C\uDFF0", rarity: "Rare", cash: [32e3, 1e5, 9e5, 9e6, 6e7], time: [4, 3, 3, 3, 2], price: [18e5, 19e6, 22e7, 24e8] }, { name: "Caterpillar", color: "#00c0f3", class: "\uD83C\uDFF0", rarity: "Epic", cash: [1e4, 7e4, 65e4, 75e5, 85e6], time: [1, 1, 1, 1, 1], price: [42e5, 42e6, 54e7, 69e8] }, { name: "Mad Hatter", color: "#914f93", class: "\uD83C\uDFF0", rarity: "Epic", cash: [38e3, 25e4, 15e5, 14e6, 8e7], time: [3, 3, 2, 2, 1], price: [48e5, 48e6, 52e7, 66e8] }, { name: "King of Hearts", color: "#c62127", class: "\uD83C\uDFF0", rarity: "Legendary", cash: [8e4, 42e4, 68e5, 1e8, 15e8], time: [5, 5, 5, 5, 5], price: [7e6, 11e7, 18e8, 3e10] }, { name: "Earth", color: "#416eb5", class: "\uD83D\uDE80", rarity: "Uncommon", cash: [15e3, 45e3, 6e5, 65e5, 65e6], time: [3, 3, 3, 3, 3], price: [1e6, 11e6, 15e7, 17e8] }, { name: "Meteor", color: "#c68c3c", class: "\uD83D\uDE80", rarity: "Uncommon", cash: [23e3, 65e3, 7e5, 45e5, 2e7], time: [5, 4, 3, 2, 1], price: [95e4, 13e6, 16e7, 16e8] }, { name: "Stars", color: "#19184d", class: "\uD83D\uDE80", rarity: "Uncommon", cash: [1e4, 4e4, 2e5, 2e6, 18e6], time: [2, 2, 1, 1, 1], price: [14e5, 14e6, 15e7, 15e8] }, { name: "Alien", color: "#8dc63f", class: "\uD83D\uDE80", rarity: "Uncommon", cash: [3e4, 1e5, 1e6, 11e6, 85e6], time: [4, 4, 4, 4, 4], price: [15e5, 17e6, 19e7, 17e8] }, { name: "Planet", color: "#9dc6ea", class: "\uD83D\uDE80", rarity: "Rare", cash: [25e3, 1e5, 9e5, 9e6, 9e7], time: [3, 3, 3, 3, 3], price: [2e6, 21e6, 21e7, 24e8] }, { name: "UFO", color: "#a15095", class: "\uD83D\uDE80", rarity: "Rare", cash: [17e3, 7e4, 7e5, 7e6, 7e7], time: [2, 2, 2, 2, 2], price: [21e5, 23e6, 25e7, 28e8] }, { name: "Spaceship", color: "#ffcb29", class: "\uD83D\uDE80", rarity: "Epic", cash: [6e4, 32e4, 21e5, 15e6, 85e6], time: [5, 4, 3, 2, 1], price: [48e5, 46e6, 54e7, 68e8] }, { name: "Astronaut", color: "#9bd4ee", class: "\uD83D\uDE80", rarity: "Legendary", cash: [45e3, 26e4, 25e5, 38e6, 55e7], time: [3, 3, 2, 2, 2], price: [65e5, 1e8, 17e8, 27e9] }, { name: "Lil Bot", color: "#3e564a", class: "\uD83E\uDD16", rarity: "Uncommon", cash: [4e3, 12e3, 18e4, 19e5, 25e6], time: [1, 1, 1, 1, 1], price: [73e4, 12e6, 13e7, 19e8] }, { name: "Lovely Bot", color: "#f179af", class: "\uD83E\uDD16", rarity: "Uncommon", cash: [16e3, 65e3, 65e4, 48e5, 42e6], time: [3, 3, 3, 2, 2], price: [13e5, 14e6, 17e7, 16e8] }, { name: "Angry Bot", color: "#f1613a", class: "\uD83E\uDD16", rarity: "Uncommon", cash: [22e3, 85e3, 8e5, 62e5, 65e6], time: [4, 4, 4, 3, 3], price: [12e5, 13e6, 15e7, 17e8] }, { name: "Happy Bot", color: "#51ba6b", class: "\uD83E\uDD16", rarity: "Uncommon", cash: [11e3, 45e3, 5e5, 25e5, 3e7], time: [2, 2, 2, 1, 1], price: [14e5, 15e6, 18e7, 24e8] }, { name: "Watson", color: "#d69b5a", class: "\uD83E\uDD16", rarity: "Rare", cash: [24e3, 1e5, 1e6, 1e7, 1e8], time: [3, 3, 3, 3, 3], price: [2e6, 22e6, 24e7, 26e8] }, { name: "Buddy Bot", color: "#9dc6ea", class: "\uD83E\uDD16", rarity: "Rare", cash: [22e3, 95e3, 65e4, 65e5, 65e6], time: [3, 3, 2, 2, 2], price: [19e5, 21e6, 23e7, 25e8] }, { name: "Brainy Bot", color: "#9ecf7a", class: "\uD83E\uDD16", rarity: "Epic", cash: [5e4, 25e4, 21e5, 21e6, 17e7], time: [4, 3, 3, 3, 2], price: [5e6, 46e6, 5e8, 67e8] }, { name: "Mega Bot", color: "#d71f27", class: "\uD83E\uDD16", rarity: "Legendary", cash: [8e4, 43e4, 42e5, 62e6, 1e9], time: [5, 5, 3, 3, 3], price: [7e6, 12e7, 19e8, 35e9] }].map(x => ({ name: x.name, value: JSON.stringify(x) }))
  1459. }],
  1460. run: function (blook) {
  1461. const stateNode = getStateNode();
  1462. if (stateNode.state.blooks.length >= 10) alert("Choose a blook to replace");
  1463. stateNode.waiting = false;
  1464. stateNode.chooseBlook(JSON.parse(blook));
  1465. }
  1466. },
  1467. {
  1468. name: "Free Upgrades",
  1469. description: "Sets upgrade prices to 0 for all current blooks",
  1470. run: function () {
  1471. const prices = [0, 0, 0, 0];
  1472. let stateNode = getStateNode();
  1473. stateNode.setState({ blooks: stateNode.state.blooks.map(blook => (blook.price = prices, blook)) });
  1474. }
  1475. },
  1476. {
  1477. name: "Max Blooks",
  1478. description: "Maxes out all your blooks' levels",
  1479. run: function () {
  1480. getStateNode().state.blooks.forEach(blook => blook.level = 4);
  1481. }
  1482. },
  1483. {
  1484. name: "Remove Glitches",
  1485. description: "Removes all enemy glitches",
  1486. run: function () {
  1487. let stateNode = getStateNode();
  1488. stateNode.setState({
  1489. bits: 0,
  1490. ads: [],
  1491. hazards: [],
  1492. color: "",
  1493. lol: false,
  1494. joke: false,
  1495. slow: false,
  1496. dance: false,
  1497. glitch: "",
  1498. glitcherName: "",
  1499. glitcherBlook: ""
  1500. });
  1501. clearTimeout(stateNode.adTimeout);
  1502. clearInterval(stateNode.hazardInterval);
  1503. clearTimeout(stateNode.nightTimeout);
  1504. clearTimeout(stateNode.glitchTimeout);
  1505. clearTimeout(stateNode.lolTimeout);
  1506. clearTimeout(stateNode.jokeTimeout);
  1507. clearTimeout(stateNode.slowTimeout);
  1508. clearTimeout(stateNode.danceTimeout);
  1509. clearTimeout(stateNode.nameTimeout);
  1510. }
  1511. },
  1512. {
  1513. name: "Send Glitch",
  1514. description: "Sends a glitch to everyone else playing",
  1515. inputs: [{
  1516. name: "Glitch",
  1517. type: "options",
  1518. options: Object.entries({ lb: "Lunch Break", as: "Ad Spam", e37: "Error 37", nt: "Night Time", lo: "#LOL", j: "Jokester", sm: "Slow Mo", dp: "Dance Party", v: "Vortex", r: "Reverse", f: "Flip", m: "Micro" }).map(([value, name]) => ({ name, value }))
  1519. }],
  1520. run: function (val) {
  1521. let stateNode = getStateNode();
  1522. stateNode.safe = true;
  1523. stateNode.props.liveGameController.setVal({ path: `c/${stateNode.props.client.name}/tat`, val });
  1524. }
  1525. },
  1526. {
  1527. name: "Set All MegaBot",
  1528. description: "Sets all your blooks to maxed out Mega Bots",
  1529. run: function () {
  1530. getStateNode().setState({
  1531. blooks: Array.from({ length: 10 }, () => ({
  1532. name: "Mega Bot",
  1533. color: "#d71f27",
  1534. class: "🤖",
  1535. rarity: "Legendary",
  1536. cash: [8e4, 43e4, 42e5, 62e6, 1e9],
  1537. time: [5, 5, 3, 3, 3],
  1538. price: [7e6, 12e7, 19e8, 35e9],
  1539. active: false,
  1540. level: 4,
  1541. bonus: 5.5
  1542. }))
  1543. });
  1544. }
  1545. },
  1546. {
  1547. name: "Set Cash",
  1548. description: "Sets amount of cash you have",
  1549. inputs: [{
  1550. name: "Cash",
  1551. type: "number"
  1552. }],
  1553. run: function (cash) {
  1554. getStateNode().setState({ cash });
  1555. }
  1556. }
  1557. ],
  1558. },
  1559. fishing: {
  1560. name: "Fishing Frenzy",
  1561. img: "https://media.blooket.com/image/upload/v1661496295/Media/uiTest/Fish_Weight.svg",
  1562. cheats: [
  1563. {
  1564. name: "Remove Distractions",
  1565. description: "Removes distractions",
  1566. type: "toggle",
  1567. enabled: false,
  1568. data: null,
  1569. run: function () {
  1570. if (!this.enabled) {
  1571. this.enabled = true;
  1572. this.data = setInterval(() => {
  1573. getStateNode().setState({ party: "" });
  1574. }, 50);
  1575. } else {
  1576. this.enabled = false;
  1577. clearInterval(this.data);
  1578. this.data = null;
  1579. }
  1580. }
  1581. },
  1582. {
  1583. name: "Frenzy",
  1584. description: "Sets everyone to frenzy mode",
  1585. run: function () {
  1586. let stateNode = getStateNode();
  1587. stateNode.props.liveGameController.setVal({
  1588. path: `c/${stateNode.props.client.name}`,
  1589. val: {
  1590. b: stateNode.props.client.blook,
  1591. w: stateNode.state.weight,
  1592. f: "Frenzy",
  1593. s: true
  1594. }
  1595. });
  1596. }
  1597. },
  1598. {
  1599. name: "Send Distraction",
  1600. description: "Sends a distraction to everyone",
  1601. inputs: [{
  1602. name: "Distraction",
  1603. type: "options",
  1604. options: ["Crab", "Jellyfish", "Frog", "Pufferfish", "Octopus", "Narwhal", "Megalodon", "Blobfish", "Baby Shark"]
  1605. }],
  1606. run: function (f) {
  1607. let stateNode = getStateNode();
  1608. stateNode.safe = true;
  1609. stateNode.props.liveGameController.setVal({
  1610. path: `c/${stateNode.props.client.name}`,
  1611. val: {
  1612. b: stateNode.props.client.blook,
  1613. w: stateNode.state.weight, f, s: true
  1614. }
  1615. });
  1616. }
  1617. },
  1618. {
  1619. name: "Set Lure",
  1620. description: "Sets fishing lure (range 1 - 5)",
  1621. inputs: [{
  1622. name: "Lure (1 - 5)",
  1623. type: "number",
  1624. min: 1,
  1625. max: 5
  1626. }],
  1627. run: function (lure) {
  1628. getStateNode().setState({ lure: Math.max(Math.min(lure - 1, 4), 0) });
  1629. }
  1630. },
  1631. {
  1632. name: "Set Weight",
  1633. description: "Sets weight",
  1634. inputs: [{
  1635. name: "Weight",
  1636. type: "number"
  1637. }],
  1638. run: function (weight) {
  1639. let stateNode = getStateNode();
  1640. stateNode.setState({ weight, weight2: weight });
  1641. stateNode.props.liveGameController.setVal({
  1642. path: `c/${stateNode.props.client.name}`,
  1643. val: {
  1644. b: stateNode.props.client.blook,
  1645. w: weight,
  1646. f: ["Crab", "Jellyfish", "Frog", "Pufferfish", "Octopus", "Narwhal", "Megalodon", "Blobfish", "Baby Shark"][Math.floor(Math.random() * 9)]
  1647. }
  1648. });
  1649. }
  1650. }
  1651. ],
  1652. },
  1653. flappy: {
  1654. name: "Flappy Blook",
  1655. img: "https://media.blooket.com/image/upload/v1645222006/Blooks/yellowBird.svg",
  1656. cheats: [
  1657. {
  1658. name: "Toggle Ghost",
  1659. description: "Lets you go through the pipes",
  1660. type: "toggle",
  1661. enabled: false,
  1662. run: function () {
  1663. this.enabled = !this.enabled;
  1664. for (const body of Object.values(document.querySelector("#phaser-bouncy"))[0].return.updateQueue.lastEffect.deps[0].current.config.sceneConfig.physics.world.bodies.entries) {
  1665. if (!body.gameObject.frame.texture.key.startsWith("blook")) continue;
  1666. body.checkCollision.none = this.enabled;
  1667. body.gameObject.setAlpha(this.enabled ? 0.5 : 1);
  1668. break;
  1669. };
  1670. }
  1671. },
  1672. {
  1673. name: "Set Score",
  1674. description: "Sets flappy blook score",
  1675. inputs: [{
  1676. name: "Score",
  1677. type: "number"
  1678. }],
  1679. run: function (score) {
  1680. Object.values(document.querySelector("#phaser-bouncy"))[0].return.updateQueue.lastEffect.deps[1](score || 0);
  1681. }
  1682. }
  1683. ],
  1684. },
  1685. gold: {
  1686. name: "Gold Quest",
  1687. img: "https://media.blooket.com/image/upload/v1661496292/Media/uiTest/Gold.svg",
  1688. cheats: [
  1689. {
  1690. name: "Always Triple",
  1691. description: "Always get triple gold",
  1692. type: "toggle",
  1693. enabled: false,
  1694. data: { type: "multiply", val: 3, text: "Triple Gold!", blook: "Unicorn" },
  1695. run: function () {
  1696. let stateNode = getStateNode();
  1697. stateNode._choosePrize ||= stateNode.choosePrize;
  1698. if (!this.enabled) {
  1699. this.enabled = true;
  1700. stateNode.choosePrize = function (i) {
  1701. stateNode.state.choices[i] = this.data;
  1702. stateNode._choosePrize(i);
  1703. }
  1704. } else {
  1705. this.enabled = false;
  1706. if (stateNode._choosePrize) stateNode.choosePrize = stateNode._choosePrize;
  1707. }
  1708. }
  1709. },
  1710. {
  1711. name: "Auto Choose",
  1712. description: "Automatically picks the option that would give you the most gold",
  1713. type: "toggle",
  1714. enabled: false,
  1715. data: null,
  1716. run: function () {
  1717. if (!this.enabled) {
  1718. this.enabled = true;
  1719. this.data = setInterval(async () => {
  1720. let stateNode = getStateNode();
  1721. if (stateNode.state.stage == "prize") {
  1722. stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
  1723. try {
  1724. if (players == null) return;
  1725. players = Object.entries(players);
  1726. let most = 0, max = 0, index = -1;
  1727. for (let i = 0; i < players.length; i++)
  1728. if (players[i][0] != stateNode.props.client.name && players[i][1] > most)
  1729. most = players[i][1];
  1730. for (let i = 0; i < stateNode.state.choices.length; i++) {
  1731. const choice = stateNode.state.choices[i];
  1732. let value = stateNode.state.gold;
  1733. if (choice.type == "gold")
  1734. value = stateNode.state.gold + choice.val || stateNode.state.gold;
  1735. else if (choice.type == "multiply" || choice.type == "divide")
  1736. value = Math.round(stateNode.state.gold * choice.val) || stateNode.state.gold;
  1737. else if (choice.type == "swap")
  1738. value = most || stateNode.state.gold;
  1739. else if (choice.type == "take")
  1740. value = stateNode.state.gold + most * choice.val || stateNode.state.gold;
  1741. if ((value || 0) <= max) continue;
  1742. max = value;
  1743. index = i + 1;
  1744. }
  1745. document.querySelector("div[class*='choice" + index + "']")?.click();
  1746. } catch { }
  1747. });
  1748. }
  1749. }, 50);
  1750. } else {
  1751. this.enabled = false;
  1752. clearInterval(this.data);
  1753. this.data = null;
  1754. }
  1755. }
  1756. },
  1757. {
  1758. name: "Chest ESP",
  1759. description: "Shows what each chest will give you",
  1760. type: "toggle",
  1761. enabled: false,
  1762. data: null,
  1763. run: function () {
  1764. if (!this.enabled) {
  1765. this.enabled = true;
  1766. this.data = setInterval(() => {
  1767. getStateNode().state.choices.forEach(({ text }, index) => {
  1768. let chest = document.querySelector(`div[class*='choice${index + 1}']`);
  1769. if (!chest || chest.querySelector('div')) return;
  1770. let choice = document.createElement('div')
  1771. choice.style.color = "white";
  1772. choice.style.fontFamily = "Eczar";
  1773. choice.style.fontSize = "2em";
  1774. choice.style.display = "flex";
  1775. choice.style.justifyContent = "center";
  1776. choice.style.transform = "translateY(200px)";
  1777. choice.innerText = text;
  1778. chest.append(choice)
  1779. });
  1780. }, 50);
  1781. } else {
  1782. this.enabled = false;
  1783. clearInterval(this.data);
  1784. this.data = null;
  1785. }
  1786. }
  1787. },
  1788. {
  1789. name: "Reset Players Gold",
  1790. description: "Sets a player's gold to 0",
  1791. inputs: [{
  1792. name: "Player",
  1793. type: "options",
  1794. options: () => {
  1795. let stateNode = getStateNode();
  1796. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  1797. }
  1798. }],
  1799. run: function (target) {
  1800. let stateNode = getStateNode();
  1801. stateNode.props.liveGameController.setVal({
  1802. path: "c/" + stateNode.props.client.name + "/tat",
  1803. val: target + ":swap:0"
  1804. });
  1805. }
  1806. },
  1807. {
  1808. name: "Set Gold",
  1809. description: "Sets amount of gold",
  1810. inputs: [{
  1811. name: "Gold",
  1812. type: "number"
  1813. }],
  1814. run: function (gold) {
  1815. let stateNode = getStateNode();
  1816. stateNode.setState({ gold, gold2: gold });
  1817. stateNode.props.liveGameController.setVal({
  1818. path: "c/" + stateNode.props.client.name + "/g",
  1819. val: gold
  1820. });
  1821. }
  1822. },
  1823. {
  1824. name: "Swap Gold",
  1825. description: "Swaps gold with someone",
  1826. inputs: [{
  1827. name: "Player",
  1828. type: "options",
  1829. options: () => {
  1830. let stateNode = getStateNode();
  1831. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  1832. }
  1833. }],
  1834. run: function (player) {
  1835. let stateNode = getStateNode();
  1836. stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
  1837. if (!players || players[player] == null) return;
  1838. const gold = players[player].g || 0;
  1839. stateNode.props.liveGameController.setVal({
  1840. path: "c/" + stateNode.props.client.name,
  1841. val: {
  1842. b: stateNode.props.client.blook,
  1843. tat: player + ":swap:" + (stateNode.state.gold || 0),
  1844. g: gold
  1845. }
  1846. });
  1847. stateNode.setState({ gold, gold2: gold });
  1848. });
  1849. }
  1850. }
  1851. ],
  1852. },
  1853. kingdom: {
  1854. name: "Crazy Kingdom",
  1855. img: "https://media.blooket.com/image/upload/v1655161323/Media/survivor/Jester_lvl1.svg",
  1856. cheats: [
  1857. {
  1858. name: "Choice ESP",
  1859. description: "Shows you what will happen if you say Yes or No",
  1860. type: "toggle",
  1861. enabled: false,
  1862. data: null,
  1863. run: function () {
  1864. if (!this.enabled) {
  1865. this.enabled = true;
  1866. this.data = setInterval(stats => {
  1867. let stateNode = getStateNode();
  1868. let elements = Array.prototype.reduce.call(document.querySelectorAll('[class*=statContainer]'), (obj, container, i) => (obj[stats[i]] = container, obj), {});
  1869. if (stateNode.state.phase == "choice") {
  1870. Array.prototype.forEach.call(document.querySelectorAll('.choiceESP'), x => x.remove());
  1871. Object.keys(stateNode.state.guest.yes || {}).forEach(x => {
  1872. if (elements[x] == null) return;
  1873. let element = document.createElement('div');
  1874. element.className = 'choiceESP';
  1875. element.style = 'font-size: 24px; color: rgb(75, 194, 46); font-weight: bolder;';
  1876. element.innerText = String(stateNode.state.guest.yes[x]);
  1877. elements[x].appendChild(element);
  1878. });
  1879. Object.keys(stateNode.state.guest.no || {}).forEach(x => {
  1880. if (elements[x] == null) return;
  1881. let element = document.createElement('div');
  1882. element.className = 'choiceESP';
  1883. element.style = 'font-size: 24px; color: darkred; font-weight: bolder;';
  1884. element.innerText = String(stateNode.state.guest.no[x]);
  1885. elements[x].appendChild(element);
  1886. });
  1887. Array.prototype.forEach.call(document.querySelectorAll("[class*=guestButton][role=button]"), x => (x.onclick = () => Array.prototype.forEach.call(document.querySelectorAll(".choiceESP"), x => x.remove())));
  1888. }
  1889. }, 50, ['materials', 'people', 'happiness', 'gold']);
  1890. } else {
  1891. this.enabled = false;
  1892. clearInterval(this.data);
  1893. Array.prototype.forEach.call(document.querySelectorAll('.choiceESP'), x => x.remove());
  1894. this.data = null;
  1895. }
  1896. }
  1897. },
  1898. {
  1899. name: "Disable Tax Toucan",
  1900. description: "Tax evasion",
  1901. run: function () {
  1902. getStateNode().taxCounter = Number.MAX_VALUE;
  1903. }
  1904. },
  1905. {
  1906. name: "Max Stats",
  1907. description: "Sets all resources to the max",
  1908. run: function () {
  1909. getStateNode().setState({ materials: 100, people: 100, happiness: 100, gold: 100 });
  1910. }
  1911. },
  1912. {
  1913. name: "Set Guests",
  1914. description: "Sets the amount of guests you've seen",
  1915. inputs: [{
  1916. name: "Guests",
  1917. type: "number"
  1918. }],
  1919. run: function (guestScore) {
  1920. getStateNode().setState({ guestScore });
  1921. }
  1922. },
  1923. {
  1924. name: "Skip Guest",
  1925. description: "Skips the current guest",
  1926. run: function () {
  1927. getStateNode().nextGuest();
  1928. }
  1929. }
  1930. ],
  1931. },
  1932. racing: {
  1933. name: "Racing",
  1934. img: "https://media.blooket.com/image/upload/v1661496295/Media/uiTest/Racing_Progress.svg",
  1935. cheats: [
  1936. {
  1937. name: "Instant Win",
  1938. description: "Instantly Wins the race",
  1939. run: function () {
  1940. const stateNode = getStateNode();
  1941. stateNode.setState({ progress: stateNode.state.goalAmount });
  1942. stateNode.props.liveGameController.setVal({
  1943. path: "c/" + stateNode.props.client.name + "/pr",
  1944. val: stateNode.state.goalAmount
  1945. });
  1946. }
  1947. },
  1948. {
  1949. name: "Set Questions",
  1950. description: "Sets the number of questions left",
  1951. inputs: [{
  1952. name: "Questions",
  1953. type: "number"
  1954. }],
  1955. run: function (progress) {
  1956. let stateNode = getStateNode();
  1957. progress = stateNode.props.client.amount - progress;
  1958. stateNode.setState({ progress });
  1959. stateNode.props.liveGameController.setVal({
  1960. path: "c/" + stateNode.props.client.name + "/pr",
  1961. val: progress
  1962. });
  1963. }
  1964. }
  1965. ],
  1966. },
  1967. royale: {
  1968. name: "Battle Royale",
  1969. img: "https://media.blooket.com/image/upload/v1655936179/Media/br/VS_Lightning_Bolt_Bottom.svg",
  1970. cheats: [
  1971. {
  1972. name: "Auto Answer (Toggle)",
  1973. description: "Toggles auto answer on",
  1974. type: "toggle",
  1975. enabled: false,
  1976. data: null,
  1977. run: function () {
  1978. if (!this.enabled) {
  1979. this.enabled = true;
  1980. this.data = setInterval(() => {
  1981. let stateNode = getStateNode();
  1982. stateNode?.onAnswer?.(true, stateNode.props.client.question.correctAnswers[0]);
  1983. }, 50);
  1984. } else {
  1985. this.enabled = false;
  1986. clearInterval(this.data);
  1987. this.data = null;
  1988. }
  1989. }
  1990. },
  1991. {
  1992. name: "Auto Answer",
  1993. description: "Chooses the correct answer for you",
  1994. run: function () {
  1995. let stateNode = getStateNode();
  1996. stateNode?.onAnswer?.(true, stateNode.props.client.question.correctAnswers[0]);
  1997. }
  1998. },
  1999. ],
  2000. },
  2001. rush: {
  2002. name: "Blook Rush",
  2003. img: "https://ac.blooket.com/games-l/assets/shield-DEeSqHMF.png",
  2004. cheats: [
  2005. {
  2006. name: "Set Blooks",
  2007. description: "Sets amount of blooks you or your team has",
  2008. inputs: [{
  2009. name: "Blooks",
  2010. type: "number"
  2011. }],
  2012. run: function (numBlooks) {
  2013. let stateNode = getStateNode();
  2014. stateNode.setState({ numBlooks });
  2015. stateNode.props.liveGameController.setVal({
  2016. path: (stateNode.isTeam ? "a/" : "c/") + stateNode.props.client.name + "/bs",
  2017. val: numBlooks
  2018. });
  2019. }
  2020. },
  2021. {
  2022. name: "Set Defense",
  2023. description: "Sets amount of defense you or your team has (Max 4)",
  2024. inputs: [{
  2025. name: "Defense (max 4)",
  2026. type: "number",
  2027. max: 4
  2028. }],
  2029. run: function (defense) {
  2030. let numDefense = Math.min(defense, 4);
  2031. let stateNode = getStateNode();
  2032. stateNode.setState({ numDefense });
  2033. stateNode.props.liveGameController.setVal({
  2034. path: (stateNode.isTeam ? "a/" : "c/") + stateNode.props.client.name + "/d",
  2035. val: numDefense
  2036. });
  2037. }
  2038. }
  2039. ],
  2040. },
  2041. workshop: {
  2042. name: "Santa's Workshop",
  2043. img: "https://ac.blooket.com/games-l/assets/toy-CO4-YS66.svg",
  2044. cheats: [
  2045. {
  2046. name: "Remove Distractions",
  2047. description: "Removes all enemy distractions",
  2048. run: function () {
  2049. getStateNode().setState({ fog: !1, dusk: !1, wind: !1, plow: !1, blizzard: !1, force: !1, canada: !1, trees: [!1, !1, !1, !1, !1, !1, !1, !1, !1, !1] });
  2050. }
  2051. },
  2052. {
  2053. name: "Send Distraction",
  2054. description: "Sends a distraction to everyone else playing",
  2055. inputs: [{
  2056. name: "Distraction",
  2057. type: "options",
  2058. options: Object.entries({ c: "Oh Canada", b: "Blizzard", f: "Fog Spell", d: "Dark & Dusk", w: "Howling Wind", g: "Gift Time!", t: "TREES", s: "Snow Plow", fr: "Use The Force" }).map(([value, name]) => ({ name, value }))
  2059. }],
  2060. run: function (val) {
  2061. let stateNode = getStateNode();
  2062. stateNode.safe = true;
  2063. stateNode.props.liveGameController.setVal({ path: `c/${stateNode.props.client.name}/tat`, val });
  2064. }
  2065. },
  2066. {
  2067. name: "Set Toys",
  2068. description: "Sets amount of toys",
  2069. inputs: [{
  2070. name: "Toys",
  2071. type: "number"
  2072. }],
  2073. run: function (toys) {
  2074. let stateNode = getStateNode();
  2075. stateNode.setState({ toys });
  2076. stateNode.props.liveGameController.setVal({
  2077. path: "c/" + stateNode.props.client.name + "/t",
  2078. val: toys
  2079. });
  2080. }
  2081. },
  2082. {
  2083. name: "Set Toys Per Question",
  2084. description: "Sets amount of toys per question",
  2085. inputs: [{
  2086. name: "Toys Per Question",
  2087. type: "number"
  2088. }],
  2089. run: function (toysPerQ) {
  2090. getStateNode().setState({ toysPerQ });
  2091. }
  2092. },
  2093. {
  2094. name: "Swap Toys",
  2095. description: "Swaps toys with someone",
  2096. inputs: [{
  2097. name: "Player",
  2098. type: "options",
  2099. options: () => {
  2100. let stateNode = getStateNode();
  2101. return stateNode.props.liveGameController._liveApp ? new Promise(res => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
  2102. }
  2103. }],
  2104. run: function (target) {
  2105. let stateNode = getStateNode();
  2106. stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
  2107. if (!players || players[target] == null) return;
  2108. stateNode.props.liveGameController.setVal({
  2109. path: "c/" + stateNode.props.client.name + "/tat",
  2110. val: `${target}:swap:${stateNode.state.toys}`
  2111. });
  2112. stateNode.setState({ toys: players[target].t });
  2113. });
  2114. }
  2115. }
  2116. ],
  2117. },
  2118. settings: {
  2119. name: "Settings",
  2120. img: null,
  2121. cheats: [
  2122. {
  2123. name: "Import Settings",
  2124. description: "Import a custom theme",
  2125. inputs: [
  2126. {
  2127. name: "JSON Data",
  2128. type: "string"
  2129. }
  2130. ],
  2131. run: function (theme) {
  2132. try {
  2133. JSON.parse(theme);
  2134. } catch (e) {
  2135. return alert("Invalid JSON provided");
  2136. }
  2137. theme = { backgroundColor: "rgb(11, 194, 207)", infoColor: "#9a49aa", cheatList: "#9a49aa", defaultButton: "#9a49aa", disabledButton: "#A02626", enabledButton: "#47A547", textColor: "white", inputColor: "#7a039d", contentBackground: "rgb(64, 17, 95)", ...JSON.parse(theme) }
  2138. settings.setItem("theme", theme);
  2139. }
  2140. },
  2141. {
  2142. name: "Export Settings",
  2143. description: "Export the current theme to JSON",
  2144. run: async function () {
  2145. await navigator.clipboard.writeText(JSON.stringify(settings.data.theme, null, 4));
  2146. prompt("Text copied to clipboard. (Paste below to test)");
  2147. }
  2148. },
  2149. {
  2150. name: "Defaults",
  2151. description: "Changes all the settings to a preset",
  2152. inputs: [
  2153. {
  2154. name: "Theme",
  2155. type: "options",
  2156. options: [
  2157. {
  2158. name: "Default",
  2159. value: {
  2160. backgroundColor: "rgb(11, 194, 207)",
  2161. infoColor: "#9a49aa",
  2162. cheatList: "#9a49aa",
  2163. defaultButton: "#9a49aa",
  2164. disabledButton: "#A02626",
  2165. enabledButton: "#47A547",
  2166. textColor: "white",
  2167. inputColor: "#7a039d",
  2168. contentBackground: "rgb(64, 17, 95)"
  2169. }
  2170. },
  2171. {
  2172. name: "Blacket",
  2173. value: {
  2174. backgroundColor: "#4f4f4f",
  2175. infoColor: "#2f2f2f",
  2176. cheatList: "#2f2f2f",
  2177. defaultButton: "#4f4f4f",
  2178. disabledButton: "#eb6234",
  2179. enabledButton: "#00c20c",
  2180. textColor: "white",
  2181. inputColor: "#3f3f3f",
  2182. contentBackground: "#2f2f2f"
  2183. }
  2184. },
  2185. {
  2186. name: "Skool.lol",
  2187. value: {
  2188. backgroundColor: "linear-gradient(90deg, rgba(104,45,140,1) 220px, rgba(237,30,121,1) 100%)",
  2189. cheatList: "#1e2124",
  2190. infoColor: "#1e2124",
  2191. defaultButton: "#36393e",
  2192. inputColor: "#1e2124",
  2193. enabledButton: "#9c9a9a",
  2194. textColor: "white",
  2195. disabledButton: "#171717",
  2196. contentBackground: "#292929"
  2197. }
  2198. },
  2199. {
  2200. name: "Blue - Purple Background",
  2201. value: {
  2202. backgroundColor: "linear-gradient(162.5deg, rgba(0,183,255,1) 220px, rgba(128,0,255,1) 100%)"
  2203. }
  2204. },
  2205. {
  2206. name: "Saint Patricks Background",
  2207. value: {
  2208. backgroundColor: "rgb(9, 148, 65)"
  2209. }
  2210. },
  2211. {
  2212. name: "Halloween Background",
  2213. value: {
  2214. backgroundColor: "rgb(41, 41, 41)"
  2215. }
  2216. },
  2217. {
  2218. name: "Fall Background",
  2219. value: {
  2220. backgroundColor: "rgb(224, 159, 62)"
  2221. }
  2222. },
  2223. {
  2224. name: "Winter Background",
  2225. value: {
  2226. backgroundColor: "linear-gradient(rgb(49, 170, 224), rgb(187, 221, 255))"
  2227. }
  2228. },
  2229. {
  2230. name: "Crypto Hack",
  2231. value: {
  2232. backgroundColor: "radial-gradient(#11581e,#041607)",
  2233. infoColor: "#1a1a1a",
  2234. cheatList: "#1a1a1a",
  2235. defaultButton: "rgb(88 175 88)",
  2236. disabledButton: "#A02626",
  2237. enabledButton: "#0b601b",
  2238. textColor: "white",
  2239. inputColor: "rgb(0 0 0 / 25%)",
  2240. contentBackground: "#11581e"
  2241. }
  2242. },
  2243. {
  2244. name: "Fishing Frenzy",
  2245. value: {
  2246. backgroundColor: "linear-gradient(180deg,#9be2fe 0,#67d1fb)",
  2247. infoColor: "#c8591e",
  2248. cheatList: "#c8591e",
  2249. defaultButton: "#ff751a",
  2250. disabledButton: "#bf0e0e",
  2251. enabledButton: "#2fb62f",
  2252. textColor: "white",
  2253. inputColor: "rgb(0 0 0 / 25%)",
  2254. contentBackground: "radial-gradient(#02b0ea 40%, #1d86ea)"
  2255. }
  2256. },
  2257. {
  2258. name: "Deceptive Dinos",
  2259. value: {
  2260. backgroundColor: "radial-gradient(rgba(220, 184, 86, 0), rgba(220, 184, 86, 0.4)), url(\"https://ac.blooket.com/play/111cb7e0ee6607ac3d1a13d534c0e0f1.png\"), #ead49a",
  2261. infoColor: "#af8942",
  2262. cheatList: "#af8942",
  2263. defaultButton: "#af8942",
  2264. disabledButton: "#A02626",
  2265. enabledButton: "#47A547",
  2266. textColor: "white",
  2267. inputColor: "rgb(0 0 0 / 10%)",
  2268. contentBackground: "radial-gradient(rgba(1,104,162,.6),rgba(24,55,110,.5)),radial-gradient(#2783b4 1.5px,#18376e 0) center / 24px 24px"
  2269. }
  2270. },
  2271. {
  2272. name: "Blook Rush",
  2273. value: {
  2274. backgroundColor: "repeating-linear-gradient(45deg,white,white 8%,#e6e6e6 0,#e6e6e6 16%)",
  2275. defaultButton: "#36c",
  2276. inputColor: "rgb(0 0 0 / 25%)",
  2277. infoColor: "#36c",
  2278. cheatList: "#36c",
  2279. contentBackground: "#888",
  2280. textColor: "white",
  2281. disabledButton: "#A02626",
  2282. enabledButton: "#47A547"
  2283. }
  2284. },
  2285. {
  2286. name: "Factory",
  2287. value: {
  2288. defaultButton: "#1563bf",
  2289. infoColor: "#a5aabe",
  2290. cheatList: "#a5aabe",
  2291. contentBackground: "#2d313d",
  2292. backgroundColor: "#3a3a3a",
  2293. enabledButton: "rgb(75, 194, 46)",
  2294. disabledButton: "#9a49aa",
  2295. inputColor: "rgb(0 0 0 / 25%)",
  2296. textColor: "white"
  2297. }
  2298. },
  2299. {
  2300. name: "Cafe",
  2301. value: {
  2302. backgroundColor: "linear-gradient(90deg,rgba(200,0,0,.5) 50%,transparent 0) center / 50px 50px,linear-gradient(rgba(200,0,0,0.5) 50%,transparent 0) white center / 50px 50px",
  2303. defaultButton: "#0bc2cf",
  2304. inputColor: "rgb(0 0 0 / 25%)",
  2305. infoColor: "#ac7339",
  2306. cheatList: "#ac7339",
  2307. contentBackground: "rgb(64, 64, 64)",
  2308. textColor: "white",
  2309. disabledButton: "#A02626",
  2310. enabledButton: "#47A547"
  2311. }
  2312. },
  2313. {
  2314. name: "Tower of Doom",
  2315. value: {
  2316. backgroundColor: "rgb(41 41 41)",
  2317. disabledButton: "rgb(151, 15, 5)",
  2318. defaultButton: "#333",
  2319. inputColor: "rgb(0 0 0 / 25%)",
  2320. contentBackground: "#404040",
  2321. enabledButton: "#4bc22e",
  2322. textColor: "white",
  2323. infoColor: "#9a49aa",
  2324. cheatList: "#9a49aa"
  2325. }
  2326. },
  2327. {
  2328. name: "Monster Brawl",
  2329. value: {
  2330. defaultButton: "rgb(45, 51, 67)",
  2331. backgroundColor: "rgb(78, 95, 124)",
  2332. inputColor: "rgb(0 0 0 / 25%)",
  2333. contentBackground: "linear-gradient(0deg,#374154,#4f5b74)",
  2334. infoColor: "#374154",
  2335. cheatList: "#374154",
  2336. textColor: "white",
  2337. enabledButton: "#47A547",
  2338. disabledButton: "#A02626"
  2339. }
  2340. },
  2341. {
  2342. name: "Tower Defense 2",
  2343. value: {
  2344. backgroundColor: "url(https://media.blooket.com/image/upload/v1676164454/Media/defense/backgroundTd1-02.svg) center / cover",
  2345. cheatList: "#a33c22",
  2346. infoColor: "#a33c22",
  2347. defaultButton: "#40b1d8",
  2348. inputColor: "#3e8cbe",
  2349. contentBackground: "#293c82",
  2350. enabledButton: "#47A547",
  2351. disabledButton: "#A02626",
  2352. textColor: "white"
  2353. }
  2354. },
  2355. ]
  2356. }
  2357. ],
  2358. run: function (theme) {
  2359. settings.setItem("theme", { ...settings.data.theme, ...theme });
  2360. }
  2361. },
  2362. {
  2363. name: "Scale",
  2364. description: "Forces the GUI to scale from 25%-100%",
  2365. inputs: [
  2366. {
  2367. type: "number",
  2368. name: "Percent scale",
  2369. min: 25,
  2370. max: 100,
  2371. value: (settings.data?.scale || 1) * 100
  2372. }
  2373. ],
  2374. run: function (scale) {
  2375. scale = Math.min(Math.max(scale, 25), 100);
  2376. settings.setItem("scale", scale / 100);
  2377. guiWrapper.style.transform = `scale(${(scale / 100)})`;
  2378. }
  2379. },
  2380. {
  2381. name: "Hide Keybind",
  2382. description: "Change the hide keybind (Click button after input to change)",
  2383. inputs: [
  2384. {
  2385. type: "function",
  2386. name: "Input",
  2387. function: onchange => createKeybindListener(({ shift, ctrl, alt, key }) => onchange(`${[ctrl && "Ctrl", shift && "Shift", alt && "Alt", key && key.toUpperCase()].filter(Boolean).join(' + ')}`))
  2388. }
  2389. ],
  2390. run: function (hide) {
  2391. settings.setItem("hide", hide);
  2392. }
  2393. },
  2394. {
  2395. name: "Close Keybind",
  2396. description: "Change the quick close keybind (Click button after input to change)",
  2397. inputs: [
  2398. {
  2399. type: "function",
  2400. name: "Input",
  2401. function: onchange => createKeybindListener(({ shift, ctrl, alt, key }) => onchange(`${[ctrl && "Ctrl", shift && "Shift", alt && "Alt", key && key.toUpperCase()].filter(Boolean).join(' + ')}`))
  2402. }
  2403. ],
  2404. run: function (close) {
  2405. settings.setItem("close", close);
  2406. }
  2407. },
  2408. {
  2409. name: "Background Color",
  2410. description: "Changes the background color of the GUI",
  2411. inputs: [{
  2412. type: "string",
  2413. name: "Color"
  2414. }],
  2415. run: function (color) {
  2416. settings.setItem("theme.backgroundColor", color);
  2417. }
  2418. },
  2419. {
  2420. name: "Category List Color",
  2421. description: "Changes the categories list background color",
  2422. inputs: [{
  2423. type: "string",
  2424. name: "Color"
  2425. }],
  2426. run: function (color) {
  2427. settings.setItem("theme.cheatList", color);
  2428. }
  2429. },
  2430. {
  2431. name: "Info Color",
  2432. description: "Changes the color of the information at the top of the GUI",
  2433. inputs: [{
  2434. type: "string",
  2435. name: "Color"
  2436. }],
  2437. run: function (color) {
  2438. settings.setItem("theme.infoColor", color);
  2439. }
  2440. },
  2441. {
  2442. name: "Button Color",
  2443. description: "Changes the color of the cheats",
  2444. inputs: [{
  2445. type: "string",
  2446. name: "Color"
  2447. }],
  2448. run: function (color) {
  2449. settings.setItem("theme.defaultButton", color);
  2450. }
  2451. },
  2452. {
  2453. name: "Enabled Toggle Color",
  2454. description: "Changes the color of enabled toggle cheats",
  2455. inputs: [{
  2456. type: "string",
  2457. name: "Color"
  2458. }],
  2459. run: function (color) {
  2460. settings.setItem("theme.enabledButton", color);
  2461. }
  2462. },
  2463. {
  2464. name: "Disabled Toggle Color",
  2465. description: "Changes the color of disabled toggle cheats",
  2466. inputs: [{
  2467. type: "string",
  2468. name: "Color"
  2469. }],
  2470. run: function (color) {
  2471. settings.setItem("theme.disabledButton", color);
  2472. }
  2473. },
  2474. {
  2475. name: "Text Color",
  2476. description: "Changes the text color",
  2477. inputs: [{
  2478. type: "string",
  2479. name: "Color"
  2480. }],
  2481. run: function (color) {
  2482. settings.setItem("theme.textColor", color);
  2483. }
  2484. },
  2485. {
  2486. name: "Input Color",
  2487. description: "Changes the color of inputs, like the set gold number input",
  2488. inputs: [{
  2489. type: "string",
  2490. name: "Color"
  2491. }],
  2492. run: function (color) {
  2493. settings.setItem("theme.inputColor", color);
  2494. }
  2495. },
  2496. {
  2497. name: "Content Color",
  2498. description: "Changes the background color of the cheats",
  2499. inputs: [{
  2500. type: "string",
  2501. name: "Color"
  2502. }],
  2503. run: function (color) {
  2504. settings.setItem("theme.contentBackground", color);
  2505. }
  2506. }
  2507. ]
  2508. },
  2509. }
  2510. const GUIContainer = document.createElement("div");
  2511. function createKeybindListener(onpress, element = window) {
  2512. return new Promise(resolve => {
  2513. const pressed = {};
  2514. let shift, ctrl, alt, key;
  2515. const keydown = e => {
  2516. e.preventDefault();
  2517. pressed[e.code] = true;
  2518. shift ||= e.shiftKey;
  2519. ctrl ||= e.ctrlKey;
  2520. alt ||= e.altKey;
  2521. if (!["shift", "control", "alt", "meta"].includes(e.key.toLowerCase())) key = e.key.toLowerCase();
  2522. onpress?.({ shift, ctrl, alt, key });
  2523. };
  2524. const keyup = e => {
  2525. delete pressed[e.code];
  2526. if (Object.keys(pressed).length > 0) return;
  2527. element.removeEventListener("keydown", keydown);
  2528. element.removeEventListener("keyup", keyup);
  2529. resolve({ shift, ctrl, alt, key });
  2530. };
  2531. element.addEventListener("keydown", keydown);
  2532. element.addEventListener("keyup", keyup);
  2533. });
  2534. }
  2535. function AntiBen({ type = "div", children, ...props }) {
  2536. let childs = [];
  2537. let char = (space) => JSX.jsx("span", {
  2538. style: {
  2539. display: "inline-block",
  2540. opacity: "0",
  2541. width: "0",
  2542. height: "0",
  2543. lineHeight: "0",
  2544. userSelect: "none",
  2545. marginLeft: space ? "5px" : null
  2546. },
  2547. children: String.fromCharCode(Math.floor(Math.random() * 25) + 97)
  2548. })
  2549. const addChar = (child) => {
  2550. if (typeof child == "string") {
  2551. let text = [];
  2552. for (let i = 0; i < child.length; i += 3) text.push(child.slice(i, i + 3), char());
  2553. childs.push(...text);
  2554. }
  2555. else childs.push(child, char());
  2556. }
  2557. if (Array.isArray(children)) for (let i = 0; i < children.length; i++) addChar(children[i]);
  2558. else addChar(children);
  2559. return JSX.jsx(type, Object.assign({ children: JSX.jsx("span", { children: childs }) }, props));
  2560. }
  2561. function ScriptInput({ input, onValue, run, toggle }) {
  2562. const { name, type, options: opts, min, max, value } = input;
  2563. let optState;
  2564. try {
  2565. optState = typeof opts == "function" ? opts() : opts;
  2566. } catch (e) {
  2567. console.warn(e);
  2568. optState = [];
  2569. }
  2570. const [options, setOptions] = useState(optState)
  2571. const [locked, setLocked] = useState("");
  2572. const loading = useRef(true);
  2573. useEffect(() => {
  2574. if (options instanceof Promise) options.then((o) => {
  2575. setOptions(o);
  2576. onValue(o[0]?.value || o[0]);
  2577. input.selected = o[0]?.name || o[0];
  2578. loading.current = false;
  2579. }).catch(() => setOptions([]));
  2580. else if (options?.length) {
  2581. onValue(options[0]?.value || options[0]);
  2582. input.selected = options[0]?.name || options[0];
  2583. }
  2584. if (type == "number") onValue(value || (min == null ? 0 : min));
  2585. else if (type == "function") onValue(null);
  2586. else if (!(options instanceof Promise) && !options?.length) onValue("");
  2587. }, []);
  2588. let el;
  2589. if (type == "options" && options?.length) el = JSX.jsx("select", {
  2590. onChange: e => (input.selected = e.target.children[e.target.selectedIndex].innerText, onValue(JSON.parse(e.target.value))),
  2591. children: options.map(opt => JSX.jsx("option", {
  2592. value: JSON.stringify(opt?.value != null ? opt.value : opt),
  2593. children: opt?.name || opt
  2594. }))
  2595. });
  2596. else if (type == "function") el = JSX.jsx("input", {
  2597. className: styles.keys.cheatInput,
  2598. placeholder: name,
  2599. style: {
  2600. textAlign: "center"
  2601. },
  2602. readOnly: true,
  2603. value: locked || input.data,
  2604. onClick: async () => {
  2605. if (locked) return;
  2606. setLocked("Waiting for input...");
  2607. let value;
  2608. const data = await input.function(e => setLocked((value = e) + "..."));
  2609. input.data = value;
  2610. setLocked(false);
  2611. onValue(data);
  2612. }
  2613. });
  2614. else {
  2615. let isNumber = type == "number";
  2616. el = JSX.jsx("input", {
  2617. onChange: e => onValue(isNumber ? parseInt(e.target.value) : e.target.value),
  2618. className: styles.keys.cheatInput,
  2619. type: isNumber ? "number" : null,
  2620. min: isNumber ? min : null,
  2621. max: isNumber ? max : null,
  2622. defaultValue: isNumber ? value || (min == null ? 0 : min) : null,
  2623. placeholder: name,
  2624. style: {
  2625. textAlign: "center",
  2626. backgroundColor: toggle && "#0003"
  2627. },
  2628. onKeyUp: e => e.key == "Enter" && run()
  2629. });
  2630. }
  2631. return el;
  2632. }
  2633. function ScriptButton({ script }) {
  2634. const args = useRef([]);
  2635. const [enabled, setEnabled] = useState(script.enabled);
  2636. const run = useCallback(() => {
  2637. script.run.apply(script, args.current);
  2638. setEnabled(script.enabled);
  2639. }, []);
  2640. return makeElement("div", {
  2641. style: {
  2642. background: script.type == "toggle" ? enabled ? "var(--enabledButton)" : "var(--disabledButton)" : "var(--defaultButton)"
  2643. },
  2644. key: script.name,
  2645. "data-tip": script.description,
  2646. className: styles.keys.scriptButton,
  2647. onClick: e => (e.target.matches(`.${styles.keys.scriptButton}`) || e.target.matches(`.${styles.keys.cheatName}`) || e.target.matches(`.${styles.keys.cheatName} *`)) && run()
  2648. }, makeElement(AntiBen, {
  2649. className: styles.keys.cheatName
  2650. }, script.name), script.inputs?.length && script.inputs.map((input, i) => input.element || makeElement(ScriptInput, {
  2651. onValue: val => args.current[i] = val,
  2652. key: i,
  2653. input: input,
  2654. run: run,
  2655. toggle: script.type == "toggle"
  2656. })));
  2657. }
  2658. function useSettings(settingsKey) {
  2659. const [data, updateData] = useState(JSON.parse(localStorage.getItem(settingsKey) || "{}"));
  2660. const setItem = useCallback((k, v) => {
  2661. k.split('.').reduce((obj, k, i, a) => (++i == a.length && (obj[k] = v), obj[k]), data);
  2662. localStorage.setItem(settingsKey, JSON.stringify(data));
  2663. updateData({ ...data });
  2664. return data;
  2665. }, [data]);
  2666. const deleteItem = useCallback((k, v) => {
  2667. k.split('.').reduce((obj, k, i, a) => (++i == a.length && (delete obj[k]), obj[k]), data);
  2668. localStorage.setItem(settingsKey, JSON.stringify(data));
  2669. updateData({ ...data });
  2670. return data;
  2671. }, [data]);
  2672. const setData = useCallback((v) => {
  2673. updateData(v);
  2674. localStorage.setItem(settingsKey, JSON.stringify(v));
  2675. }, []);
  2676. useEffect(() => {
  2677. try {
  2678. updateData(JSON.parse(localStorage.getItem(settingsKey) || "{}"));
  2679. for (const setting of ["backgroundColor", "cheatList", "contentBackground", "defaultButton", "disabledButton", "enabledButton", "infoColor", "inputColor", "textColor"]) if (settings.data[setting]) {
  2680. setItem(`theme.${setting}`, settings.data[setting]);
  2681. deleteItem(setting);
  2682. }
  2683. } catch {
  2684. setData({});
  2685. }
  2686. }, [])
  2687. return { data, setItem, deleteItem, setData };
  2688. }
  2689. function Draggable({ parent, children, setPos, ...props }) {
  2690. const mouseDown = useRef(false);
  2691. const pos = useRef({ x: 0, y: 0 });
  2692. useEffect(() => {
  2693. const pointerup = () => mouseDown.current = false;
  2694. const pointermove = (e) => {
  2695. if (!mouseDown.current) return;
  2696. let dx = pos.current.x - e.clientX;
  2697. let dy = pos.current.y - e.clientY;
  2698. pos.current = { x: e.clientX, y: e.clientY };
  2699. var ratio = 1 || parseFloat((0.75 / window.devicePixelRatio).toFixed(2));
  2700. setPos({ x: parent.offsetLeft - dx / ratio, y: parent.offsetTop - dy / ratio });
  2701. }
  2702. document.addEventListener("pointerup", pointerup);
  2703. document.addEventListener("pointermove", pointermove);
  2704. return () => {
  2705. document.removeEventListener("pointerup", pointerup);
  2706. document.removeEventListener("pointermove", pointermove);
  2707. }
  2708. }, [parent]);
  2709. return makeElement("div", {
  2710. ...props, onPointerDown: e => {
  2711. mouseDown.current = true;
  2712. pos.current = {
  2713. x: e.clientX,
  2714. y: e.clientY
  2715. };
  2716. }
  2717. }, children);
  2718. }
  2719. function GUI() {
  2720. const { current: pos } = useRef({
  2721. x: Math.max(10, window.innerWidth - 1000) / 2,
  2722. y: Math.max(10, window.innerHeight - 600) / 2,
  2723. });
  2724. const setPos = useCallback(({ x, y }) => {
  2725. pos.x = x;
  2726. pos.y = y;
  2727. guiRef.current.style.left = `${x}px`;
  2728. guiRef.current.style.top = `${y}px`;
  2729. }, []);
  2730. const [minified, setMinified] = useState(null);
  2731. const [hidden, setHidden] = useState(false);
  2732. const [currentMode, setCurrentMode] = useState("global");
  2733. const guiRef = useRef();
  2734. const alertInterval = useRef();
  2735. settings = useSettings("JODGUISETTINGS");
  2736. const variables = makeElement("style", null, `:root {--backgroundColor: ${settings.data?.theme?.backgroundColor || "rgb(11, 194, 207)"};--infoColor: ${settings.data?.theme?.infoColor || "#9a49aa"};--cheatList: ${settings.data?.theme?.cheatList || "#9a49aa"};--defaultButton: ${settings.data?.theme?.defaultButton || "#9a49aa"};--disabledButton: ${settings.data?.theme?.disabledButton || "#A02626"};--enabledButton: ${settings.data?.theme?.enabledButton || "#47A547"};--textColor: ${settings.data?.theme?.textColor || "white"};--inputColor: ${settings.data?.theme?.inputColor || "#7a039d"};--contentBackground: ${settings.data?.theme?.contentBackground || "rgb(64, 17, 95)"};}`);
  2737. const { current: gamemodes } = useRef(["global", "voyage", "gold", "cafe", "crypto", "dinos", "defense", "defense2", "factory", "fishing", "flappy", "doom", "kingdom", "racing", "royale", "rush", "brawl", "workshop", "settings"]);
  2738. const close = useCallback(() => {
  2739. ReactDOM.unmountComponentAtNode(GUIContainer);
  2740. GUIContainer.remove();
  2741. }, []);
  2742. useEffect(() => {
  2743. window.dispatchEvent(new Event("resize"));
  2744. let keydown = e => {
  2745. let hideKey = settings.data.hide || { ctrl: true, key: "e" };
  2746. let closeKey = settings.data.close || { ctrl: true, key: "x" };
  2747. if ((hideKey.ctrl && e.ctrlKey || !hideKey.ctrl && !e.ctrlKey) && (hideKey.shift && e.shiftKey || !hideKey.shift && !e.shiftKey) && (hideKey.alt && e.altKey || !hideKey.alt && !e.altKey) && e.key.toLowerCase() == hideKey.key) {
  2748. e.preventDefault();
  2749. setHidden(h => !h);
  2750. } else if ((closeKey.ctrl && e.ctrlKey || !closeKey.ctrl && !e.ctrlKey) && (closeKey.shift && e.shiftKey || !closeKey.shift && !e.shiftKey) && (closeKey.alt && e.altKey || !closeKey.alt && !e.altKey) && e.key.toLowerCase() == closeKey.key) {
  2751. e.preventDefault();
  2752. close();
  2753. }
  2754. };
  2755. window.addEventListener("keydown", keydown);
  2756. return () => {
  2757. window.removeEventListener("keydown", keydown);
  2758. for (const gamemode of gamemodes) for (const cheat of Cheats[gamemode].cheats) if (cheat.enabled) cheat.run();
  2759. }
  2760. }, []);
  2761. useEffect(() => {
  2762. if (minified == null) return () => { };
  2763. let gui = guiRef.current.querySelector("div");
  2764. gui.style.height = !minified ? "100%" : "55px";
  2765. gui.style.width = !minified ? "100%" : "165px";
  2766. guiRef.current.style.top = `${parseInt(guiRef.current.style.top) + (guiRef.current.offsetHeight - 55) * (!minified ? -1 : 1)}px`;
  2767. guiRef.current.style.left = `${parseInt(guiRef.current.style.left) + (guiRef.current.offsetWidth - 165) * (!minified ? -1 : 1)}px`;
  2768. guiRef.current.style.pointerEvents = !minified ? "unset" : "none";
  2769. }, [minified])
  2770. return makeElement("div", {
  2771. ref: guiRef,
  2772. id: styles.keys.guiWrapper,
  2773. style: {
  2774. top: `${pos.y}px`,
  2775. left: `${pos.x}px`,
  2776. transform: `scale(${settings.data.scale || 1})`,
  2777. display: hidden ? "none" : null
  2778. }
  2779. }, makeElement("style", null, styles.css), variables, makeElement("div", {
  2780. id: styles.keys.gui
  2781. }, makeElement("div", {
  2782. id: styles.keys.controlButtons
  2783. }, makeElement(Draggable, {
  2784. parent: guiRef.current,
  2785. setPos: setPos,
  2786. style: {
  2787. backgroundColor: "rgb(0, 160, 255)"
  2788. },
  2789. className: styles.keys.dragButton
  2790. }, makeElement("i", {
  2791. className: "fas fa-arrows-alt"
  2792. })), makeElement("div", {
  2793. style: {
  2794. fontWeight: "bolder",
  2795. backgroundColor: "grey",
  2796. cursor: "pointer"
  2797. },
  2798. onClick: () => setMinified(m => !m)
  2799. }, makeElement("i", {
  2800. className: "fas fa-minus"
  2801. })), makeElement("div", {
  2802. style: {
  2803. fontWeight: "bolder",
  2804. backgroundColor: "red",
  2805. cursor: "pointer"
  2806. },
  2807. onClick: close
  2808. }, makeElement("i", {
  2809. className: "fas fa-times"
  2810. }))), !minified && makeElement(React.Fragment, null, makeElement("div", {
  2811. id: styles.keys.background
  2812. }, makeElement("div", {
  2813. id: styles.keys.backgroundImage
  2814. })), makeElement(Draggable, {
  2815. parent: guiRef.current,
  2816. setPos: setPos,
  2817. id: styles.keys.controls
  2818. }, (({ ctrl: ctrlHide, shift: shiftHide, alt: altHide, key: keyHide } = { ctrl: true, key: "q" }, { ctrl: ctrlClose, shift: shiftClose, alt: altClose, key: keyClose } = { ctrl: true, key: "x" }) => {
  2819. return makeElement(React.Fragment, null, `${[ctrlHide && "Ctrl", shiftHide && "Shift", altHide && "Alt", keyHide && keyHide.toUpperCase()].filter(Boolean).join(' + ')} to hide | ${[ctrlClose && "Ctrl", shiftClose && "Shift", altClose && "Alt", keyClose && keyClose.toUpperCase()].filter(Boolean).join(' + ')} for quick disable`, makeElement("br", null), makeElement(AntiBen, null, "Click and drag here"));
  2820. })(settings.data.hide || {
  2821. ctrl: true,
  2822. key: "e"
  2823. }, settings.data.close || {
  2824. ctrl: true,
  2825. key: "x"
  2826. })), makeElement("div", {
  2827. id: styles.keys.credits
  2828. }, makeElement(AntiBen, {
  2829. onClick: () => window.open("https://github.com/Gradyruan/Blooket-cheats", "_blank").focus(),
  2830. style: {
  2831. cursor: "pointer"
  2832. },
  2833. href: "https://github.com/Gradyruan/Blooket-cheats"
  2834. }, "GitHub - Gradyruan")), makeElement("div", {
  2835. id: styles.keys.cheatList
  2836. }, makeElement(AntiBen, {
  2837. type: "span",
  2838. style: {
  2839. textShadow: "1px 1px rgb(0 0 0 / 40%)"
  2840. }
  2841. }, "Cheats"), makeElement("a", {
  2842. href: "https://discord.gg/jHjGrrdXP6",
  2843. target: "_blank",
  2844. id: styles.keys.bigButton
  2845. }, makeElement("svg", {
  2846. style: {
  2847. filter: "drop-shadow(2px 2px 0 rgb(0 0 0 / 20%))"
  2848. },
  2849. xmlns: "http://www.w3.org/2000/svg",
  2850. width: "35",
  2851. height: "35",
  2852. fill: "currentColor",
  2853. viewBox: "0 -1 21 16"
  2854. }, makeElement("path", {
  2855. d: "M13.545 2.907a13.227 13.227 0 0 0-3.257-1.011.05.05 0 0 0-.052.025c-.141.25-.297.577-.406.833a12.19 12.19 0 0 0-3.658 0 8.258 8.258 0 0 0-.412-.833.051.051 0 0 0-.052-.025c-1.125.194-2.22.534-3.257 1.011a.041.041 0 0 0-.021.018C.356 6.024-.213 9.047.066 12.032c.001.014.01.028.021.037a13.276 13.276 0 0 0 3.995 2.02.05.05 0 0 0 .056-.019c.308-.42.582-.863.818-1.329a.05.05 0 0 0-.01-.059.051.051 0 0 0-.018-.011 8.875 8.875 0 0 1-1.248-.595.05.05 0 0 1-.02-.066.051.051 0 0 1 .015-.019c.084-.063.168-.129.248-.195a.05.05 0 0 1 .051-.007c2.619 1.196 5.454 1.196 8.041 0a.052.052 0 0 1 .053.007c.08.066.164.132.248.195a.051.051 0 0 1-.004.085 8.254 8.254 0 0 1-1.249.594.05.05 0 0 0-.03.03.052.052 0 0 0 .003.041c.24.465.515.909.817 1.329a.05.05 0 0 0 .056.019 13.235 13.235 0 0 0 4.001-2.02.049.049 0 0 0 .021-.037c.334-3.451-.559-6.449-2.366-9.106a.034.034 0 0 0-.02-.019Zm-8.198 7.307c-.789 0-1.438-.724-1.438-1.612 0-.889.637-1.613 1.438-1.613.807 0 1.45.73 1.438 1.613 0 .888-.637 1.612-1.438 1.612Zm5.316 0c-.788 0-1.438-.724-1.438-1.612 0-.889.637-1.613 1.438-1.613.807 0 1.451.73 1.438 1.613 0 .888-.631 1.612-1.438 1.612Z"
  2856. })), makeElement(AntiBen, {
  2857. type: React.Fragment
  2858. }, "Discord")), gamemodes.map(gamemode => {
  2859. return makeElement("div", {
  2860. key: gamemode,
  2861. onClick: () => setCurrentMode(gamemode),
  2862. className: styles.keys.cheatButton
  2863. }, Cheats[gamemode].img ? makeElement("img", {
  2864. src: Cheats[gamemode].img,
  2865. style: {
  2866. maxWidth: "30px",
  2867. maxHeight: "30px",
  2868. aspectRatio: "1 / 1",
  2869. marginRight: "10px",
  2870. ...(Cheats[gamemode].style || {})
  2871. },
  2872. alt: gamemode
  2873. }) : makeElement("div", {
  2874. style: {
  2875. marginInline: "5px",
  2876. width: "5px"
  2877. }
  2878. }), makeElement(Textfit, {
  2879. mode: "single",
  2880. forceSingleWidthMode: false,
  2881. min: 1,
  2882. max: 20
  2883. }, Cheats[gamemode].name));
  2884. })), makeElement("div", {
  2885. id: styles.keys.contentWrapper
  2886. }, makeElement("div", {
  2887. id: styles.keys.content
  2888. }, makeElement(Tooltip, {
  2889. place: "bottom",
  2890. effect: "solid"
  2891. }), makeElement("div", {
  2892. id: styles.keys.cheats
  2893. }, Cheats[currentMode].element || (Cheats[currentMode].element = makeElement(React.Fragment, null, makeElement("div", {
  2894. className: styles.keys.headerText
  2895. }, makeElement(AntiBen, null, Cheats[currentMode].name, " Cheats")), Cheats[currentMode].cheats.map(cheat => cheat.element || makeElement(ScriptButton, {
  2896. key: cheat.name + cheat.type,
  2897. script: cheat
  2898. }))))))))));
  2899. }
  2900. console.log(JSX.jsx(GUI, {}))
  2901. ReactDOM.render(JSX.jsx(GUI, {}), GUIContainer);
  2902. document.body.append(GUIContainer);
  2903. });
  2904. let img = new Image;
  2905. img.src = "https://raw.githubusercontent.com/Gradyruan/Blooket-cheats/main/autoupdate/timestamps/reactGui.png?" + Date.now();
  2906. img.crossOrigin = "Anonymous";
  2907. img.onload = function() {
  2908. const c = document.createElement("canvas");
  2909. const ctx = c.getContext("2d");
  2910. ctx.drawImage(img, 0, 0, this.width, this.height);
  2911. let { data } = ctx.getImageData(0, 0, this.width, this.height), decode = "", last;
  2912. let i = 0;
  2913. while (i < data.length) {
  2914. let char = String.fromCharCode(data[i % 4 == 3 ? (i++, i++) : i++] + data[i % 4 == 3 ? (i++, i++) : i++] * 256);
  2915. decode += char;
  2916. if (char == "/" && last == "*") break;
  2917. last = char;
  2918. }
  2919. let _, time = 1716839383820, error = "There was an error checking for script updates. Run cheat anyway?";
  2920. try {
  2921. [_, time, error] = decode.match(/LastUpdated: (.+?); ErrorMessage: "((.|\n)+?)"/);
  2922. } catch (e) {}
  2923. if (parseInt(time) <= 1716839383820 || iframe.contentWindow.confirm(error)) cheat();
  2924. }
  2925. img.onerror = img.onabort = () => {
  2926. img.onerror = img.onabort = null;
  2927. cheat();
  2928. let iframe = document.querySelector("iframe");
  2929. iframe.contentWindow.alert("It seems the GitHub is either blocked or down.\n\nIf it's NOT blocked, join the Discord server for updates\nhttps://discord.gg/jHjGrrdXP6\n(The cheat will still run after this alert)")
  2930. }
  2931. })();
  2932. })();