NOT PATCHED ANYMORE, THE BEST GUI ON THE WEB! ADVANCED ANTIBAN AND TONS OF FEATURES {CHEAT} {HACK} {CLIENT}
// ==UserScript==
// @name X-GUI CLIENT FOR BLOOKET
// @namespace http://tampermonkey.net/
// @version 6.70x
// @description NOT PATCHED ANYMORE, THE BEST GUI ON THE WEB! ADVANCED ANTIBAN AND TONS OF FEATURES {CHEAT} {HACK} {CLIENT}
// @author Tony-the-best
// @run-at document-end
// @match *://*.blooket.com/*
// @match *://blooket.com/*
// @license APGL-3.0
// @icon https://i.ibb.co/LhDtzNd1/icon512.png
// @grant GM_getResourceText
// @grant GM_addStyle
// @require https://cdn.jsdelivr.net/npm/sweetalert2@11
// ==/UserScript==
/*!
* sweetalert2 v11.26.17
* Released under the MIT License.
*/
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).Sweetalert2=t()}(this,function(){"use strict";function e(e,t,n){if("function"==typeof e?e===t:e.has(t))return arguments.length<3?t:n;throw new TypeError("Private element is not present on this object")}function t(t,n){return t.get(e(t,n))}function n(e,t,n){(function(e,t){if(t.has(e))throw new TypeError("Cannot initialize the same private elements twice on an object")})(e,t),t.set(e,n)}const o={},i=e=>new Promise(t=>{if(!e)return t();const n=window.scrollX,i=window.scrollY;o.restoreFocusTimeout=setTimeout(()=>{o.previousActiveElement instanceof HTMLElement?(o.previousActiveElement.focus(),o.previousActiveElement=null):document.body&&document.body.focus(),t()},100),window.scrollTo(n,i)}),s="swal2-",r=["container","shown","height-auto","iosfix","popup","modal","no-backdrop","no-transition","toast","toast-shown","show","hide","close","title","html-container","actions","confirm","deny","cancel","footer","icon","icon-content","image","input","file","range","select","radio","checkbox","label","textarea","inputerror","input-label","validation-message","progress-steps","active-progress-step","progress-step","progress-step-line","loader","loading","styled","top","top-start","top-end","top-left","top-right","center","center-start","center-end","center-left","center-right","bottom","bottom-start","bottom-end","bottom-left","bottom-right","grow-row","grow-column","grow-fullscreen","rtl","timer-progress-bar","timer-progress-bar-container","scrollbar-measure","icon-success","icon-warning","icon-info","icon-question","icon-error","draggable","dragging"].reduce((e,t)=>(e[t]=s+t,e),{}),a=["success","warning","info","question","error"].reduce((e,t)=>(e[t]=s+t,e),{}),l="SweetAlert2:",c=e=>e.charAt(0).toUpperCase()+e.slice(1),u=e=>{console.warn(`${l} ${"object"==typeof e?e.join(" "):e}`)},d=e=>{console.error(`${l} ${e}`)},p=[],m=(e,t=null)=>{var n;n=`"${e}" is deprecated and will be removed in the next major release.${t?` Use "${t}" instead.`:""}`,p.includes(n)||(p.push(n),u(n))},h=e=>"function"==typeof e?e():e,g=e=>e&&"function"==typeof e.toPromise,f=e=>g(e)?e.toPromise():Promise.resolve(e),b=e=>e&&Promise.resolve(e)===e,y=()=>document.body.querySelector(`.${r.container}`),v=e=>{const t=y();return t?t.querySelector(e):null},w=e=>v(`.${e}`),C=()=>w(r.popup),A=()=>w(r.icon),E=()=>w(r.title),k=()=>w(r["html-container"]),B=()=>w(r.image),$=()=>w(r["progress-steps"]),L=()=>w(r["validation-message"]),P=()=>v(`.${r.actions} .${r.confirm}`),x=()=>v(`.${r.actions} .${r.cancel}`),T=()=>v(`.${r.actions} .${r.deny}`),S=()=>v(`.${r.loader}`),O=()=>w(r.actions),M=()=>w(r.footer),j=()=>w(r["timer-progress-bar"]),H=()=>w(r.close),I=()=>{const e=C();if(!e)return[];const t=e.querySelectorAll('[tabindex]:not([tabindex="-1"]):not([tabindex="0"])'),n=Array.from(t).sort((e,t)=>{const n=parseInt(e.getAttribute("tabindex")||"0"),o=parseInt(t.getAttribute("tabindex")||"0");return n>o?1:n<o?-1:0}),o=e.querySelectorAll('\n a[href],\n area[href],\n input:not([disabled]),\n select:not([disabled]),\n textarea:not([disabled]),\n button:not([disabled]),\n iframe,\n object,\n embed,\n [tabindex="0"],\n [contenteditable],\n audio[controls],\n video[controls],\n summary\n'),i=Array.from(o).filter(e=>"-1"!==e.getAttribute("tabindex"));return[...new Set(n.concat(i))].filter(e=>ee(e))},D=()=>N(document.body,r.shown)&&!N(document.body,r["toast-shown"])&&!N(document.body,r["no-backdrop"]),V=()=>{const e=C();return!!e&&N(e,r.toast)},q=(e,t)=>{if(e.textContent="",t){const n=(new DOMParser).parseFromString(t,"text/html"),o=n.querySelector("head");o&&Array.from(o.childNodes).forEach(t=>{e.appendChild(t)});const i=n.querySelector("body");i&&Array.from(i.childNodes).forEach(t=>{t instanceof HTMLVideoElement||t instanceof HTMLAudioElement?e.appendChild(t.cloneNode(!0)):e.appendChild(t)})}},N=(e,t)=>{if(!t)return!1;const n=t.split(/\s+/);for(let t=0;t<n.length;t++)if(!e.classList.contains(n[t]))return!1;return!0},_=(e,t,n)=>{if(((e,t)=>{Array.from(e.classList).forEach(n=>{Object.values(r).includes(n)||Object.values(a).includes(n)||Object.values(t.showClass||{}).includes(n)||e.classList.remove(n)})})(e,t),!t.customClass)return;const o=t.customClass[n];o&&("string"==typeof o||o.forEach?z(e,o):u(`Invalid type of customClass.${n}! Expected string or iterable object, got "${typeof o}"`))},R=(e,t)=>{if(!t)return null;switch(t){case"select":case"textarea":case"file":return e.querySelector(`.${r.popup} > .${r[t]}`);case"checkbox":return e.querySelector(`.${r.popup} > .${r.checkbox} input`);case"radio":return e.querySelector(`.${r.popup} > .${r.radio} input:checked`)||e.querySelector(`.${r.popup} > .${r.radio} input:first-child`);case"range":return e.querySelector(`.${r.popup} > .${r.range} input`);default:return e.querySelector(`.${r.popup} > .${r.input}`)}},F=e=>{if(e.focus(),"file"!==e.type){const t=e.value;e.value="",e.value=t}},U=(e,t,n)=>{e&&t&&("string"==typeof t&&(t=t.split(/\s+/).filter(Boolean)),t.forEach(t=>{Array.isArray(e)?e.forEach(e=>{n?e.classList.add(t):e.classList.remove(t)}):n?e.classList.add(t):e.classList.remove(t)}))},z=(e,t)=>{U(e,t,!0)},W=(e,t)=>{U(e,t,!1)},K=(e,t)=>{const n=Array.from(e.children);for(let e=0;e<n.length;e++){const o=n[e];if(o instanceof HTMLElement&&N(o,t))return o}},Y=(e,t,n)=>{n===`${parseInt(`${n}`)}`&&(n=parseInt(n)),n||0===parseInt(`${n}`)?e.style.setProperty(t,"number"==typeof n?`${n}px`:n):e.style.removeProperty(t)},X=(e,t="flex")=>{e&&(e.style.display=t)},Z=e=>{e&&(e.style.display="none")},J=(e,t="block")=>{e&&new MutationObserver(()=>{Q(e,e.innerHTML,t)}).observe(e,{childList:!0,subtree:!0})},G=(e,t,n,o)=>{const i=e.querySelector(t);i&&i.style.setProperty(n,o)},Q=(e,t,n="flex")=>{t?X(e,n):Z(e)},ee=e=>Boolean(e&&(e.offsetWidth||e.offsetHeight||e.getClientRects().length)),te=e=>Boolean(e.scrollHeight>e.clientHeight),ne=e=>{const t=window.getComputedStyle(e),n=parseFloat(t.getPropertyValue("animation-duration")||"0"),o=parseFloat(t.getPropertyValue("transition-duration")||"0");return n>0||o>0},oe=(e,t=!1)=>{const n=j();n&&ee(n)&&(t&&(n.style.transition="none",n.style.width="100%"),setTimeout(()=>{n.style.transition=`width ${e/1e3}s linear`,n.style.width="0%"},10))},ie=`\n <div aria-labelledby="${r.title}" aria-describedby="${r["html-container"]}" class="${r.popup}" tabindex="-1">\n <button type="button" class="${r.close}"></button>\n <ul class="${r["progress-steps"]}"></ul>\n <div class="${r.icon}"></div>\n <img class="${r.image}" />\n <h2 class="${r.title}" id="${r.title}"></h2>\n <div class="${r["html-container"]}" id="${r["html-container"]}"></div>\n <input class="${r.input}" id="${r.input}" />\n <input type="file" class="${r.file}" />\n <div class="${r.range}">\n <input type="range" />\n <output></output>\n </div>\n <select class="${r.select}" id="${r.select}"></select>\n <div class="${r.radio}"></div>\n <label class="${r.checkbox}">\n <input type="checkbox" id="${r.checkbox}" />\n <span class="${r.label}"></span>\n </label>\n <textarea class="${r.textarea}" id="${r.textarea}"></textarea>\n <div class="${r["validation-message"]}" id="${r["validation-message"]}"></div>\n <div class="${r.actions}">\n <div class="${r.loader}"></div>\n <button type="button" class="${r.confirm}"></button>\n <button type="button" class="${r.deny}"></button>\n <button type="button" class="${r.cancel}"></button>\n </div>\n <div class="${r.footer}"></div>\n <div class="${r["timer-progress-bar-container"]}">\n <div class="${r["timer-progress-bar"]}"></div>\n </div>\n </div>\n`.replace(/(^|\n)\s*/g,""),se=()=>{o.currentInstance&&o.currentInstance.resetValidationMessage()},re=e=>{const t=(()=>{const e=y();return!!e&&(e.remove(),W([document.documentElement,document.body],[r["no-backdrop"],r["toast-shown"],r["has-column"]]),!0)})();if("undefined"==typeof window||"undefined"==typeof document)return void d("SweetAlert2 requires document to initialize");const n=document.createElement("div");n.className=r.container,t&&z(n,r["no-transition"]),q(n,ie),n.dataset.swal2Theme=e.theme;const i=(e=>{if("string"==typeof e){const t=document.querySelector(e);if(!t)throw new Error(`Target element "${e}" not found`);return t}return e})(e.target||"body");i.appendChild(n),e.topLayer&&(n.setAttribute("popover",""),n.showPopover()),(e=>{const t=C();t&&(t.setAttribute("role",e.toast?"alert":"dialog"),t.setAttribute("aria-live",e.toast?"polite":"assertive"),e.toast||t.setAttribute("aria-modal","true"))})(e),(e=>{"rtl"===window.getComputedStyle(e).direction&&(z(y(),r.rtl),o.isRTL=!0)})(i),(()=>{const e=C();if(!e)return;const t=K(e,r.input),n=K(e,r.file),o=e.querySelector(`.${r.range} input`),i=e.querySelector(`.${r.range} output`),s=K(e,r.select),a=e.querySelector(`.${r.checkbox} input`),l=K(e,r.textarea);t&&(t.oninput=se),n&&(n.onchange=se),s&&(s.onchange=se),a&&(a.onchange=se),l&&(l.oninput=se),o&&i&&(o.oninput=()=>{se(),i.value=o.value},o.onchange=()=>{se(),i.value=o.value})})()},ae=(e,t)=>{e instanceof HTMLElement?t.appendChild(e):"object"==typeof e?le(e,t):e&&q(t,e)},le=(e,t)=>{"jquery"in e?ce(t,e):q(t,e.toString())},ce=(e,t)=>{if(e.textContent="",0 in t)for(let n=0;n in t;n++)e.appendChild(t[n].cloneNode(!0));else e.appendChild(t.cloneNode(!0))},ue=(e,t)=>{const n=O(),o=S();n&&o&&(t.showConfirmButton||t.showDenyButton||t.showCancelButton?X(n):Z(n),_(n,t,"actions"),function(e,t,n){const o=P(),i=T(),s=x();if(!o||!i||!s)return;pe(o,"confirm",n),pe(i,"deny",n),pe(s,"cancel",n),function(e,t,n,o){if(!o.buttonsStyling)return void W([e,t,n],r.styled);z([e,t,n],r.styled),o.confirmButtonColor&&e.style.setProperty("--swal2-confirm-button-background-color",o.confirmButtonColor);o.denyButtonColor&&t.style.setProperty("--swal2-deny-button-background-color",o.denyButtonColor);o.cancelButtonColor&&n.style.setProperty("--swal2-cancel-button-background-color",o.cancelButtonColor);de(e),de(t),de(n)}(o,i,s,n),n.reverseButtons&&(n.toast?(e.insertBefore(s,o),e.insertBefore(i,o)):(e.insertBefore(s,t),e.insertBefore(i,t),e.insertBefore(o,t)))}(n,o,t),q(o,t.loaderHtml||""),_(o,t,"loader"))};function de(e){const t=window.getComputedStyle(e);if(t.getPropertyValue("--swal2-action-button-focus-box-shadow"))return;const n=t.backgroundColor.replace(/rgba?\((\d+), (\d+), (\d+).*/,"rgba($1, $2, $3, 0.5)");e.style.setProperty("--swal2-action-button-focus-box-shadow",t.getPropertyValue("--swal2-outline").replace(/ rgba\(.*/,` ${n}`))}function pe(e,t,n){const o=c(t);Q(e,n[`show${o}Button`],"inline-block"),q(e,n[`${t}ButtonText`]||""),e.setAttribute("aria-label",n[`${t}ButtonAriaLabel`]||""),e.className=r[t],_(e,n,`${t}Button`)}const me=(e,t)=>{const n=y();n&&(!function(e,t){"string"==typeof t?e.style.background=t:t||z([document.documentElement,document.body],r["no-backdrop"])}(n,t.backdrop),function(e,t){if(!t)return;t in r?z(e,r[t]):(u('The "position" parameter is not valid, defaulting to "center"'),z(e,r.center))}(n,t.position),function(e,t){if(!t)return;z(e,r[`grow-${t}`])}(n,t.grow),_(n,t,"container"))};var he={innerParams:new WeakMap,domCache:new WeakMap};const ge=["input","file","range","select","radio","checkbox","textarea"],fe=e=>{if(!e.input)return;if(!Ee[e.input])return void d(`Unexpected type of input! Expected ${Object.keys(Ee).join(" | ")}, got "${e.input}"`);const t=Ce(e.input);if(!t)return;const n=Ee[e.input](t,e);X(t),e.inputAutoFocus&&setTimeout(()=>{F(n)})},be=(e,t)=>{const n=C();if(!n)return;const o=R(n,e);if(o){(e=>{for(let t=0;t<e.attributes.length;t++){const n=e.attributes[t].name;["id","type","value","style"].includes(n)||e.removeAttribute(n)}})(o);for(const e in t)o.setAttribute(e,t[e])}},ye=e=>{if(!e.input)return;const t=Ce(e.input);t&&_(t,e,"input")},ve=(e,t)=>{!e.placeholder&&t.inputPlaceholder&&(e.placeholder=t.inputPlaceholder)},we=(e,t,n)=>{if(n.inputLabel){const o=document.createElement("label"),i=r["input-label"];o.setAttribute("for",e.id),o.className=i,"object"==typeof n.customClass&&z(o,n.customClass.inputLabel),o.innerText=n.inputLabel,t.insertAdjacentElement("beforebegin",o)}},Ce=e=>{const t=C();if(t)return K(t,r[e]||r.input)},Ae=(e,t)=>{["string","number"].includes(typeof t)?e.value=`${t}`:b(t)||u(`Unexpected type of inputValue! Expected "string", "number" or "Promise", got "${typeof t}"`)},Ee={};Ee.text=Ee.email=Ee.password=Ee.number=Ee.tel=Ee.url=Ee.search=Ee.date=Ee["datetime-local"]=Ee.time=Ee.week=Ee.month=(e,t)=>{const n=e;return Ae(n,t.inputValue),we(n,n,t),ve(n,t),n.type=t.input,n},Ee.file=(e,t)=>{const n=e;return we(n,n,t),ve(n,t),n},Ee.range=(e,t)=>{const n=e,o=n.querySelector("input"),i=n.querySelector("output");return o&&(Ae(o,t.inputValue),o.type=t.input,we(o,e,t)),i&&Ae(i,t.inputValue),e},Ee.select=(e,t)=>{const n=e;if(n.textContent="",t.inputPlaceholder){const e=document.createElement("option");q(e,t.inputPlaceholder),e.value="",e.disabled=!0,e.selected=!0,n.appendChild(e)}return we(n,n,t),n},Ee.radio=e=>(e.textContent="",e),Ee.checkbox=(e,t)=>{const n=C();if(!n)throw new Error("Popup not found");const o=R(n,"checkbox");if(!o)throw new Error("Checkbox input not found");o.value="1",o.checked=Boolean(t.inputValue);const i=e.querySelector("span");if(i){const e=t.inputPlaceholder||t.inputLabel;e&&q(i,e)}return o},Ee.textarea=(e,t)=>{const n=e;Ae(n,t.inputValue),ve(n,t),we(n,n,t);return setTimeout(()=>{if("MutationObserver"in window){const e=C();if(!e)return;const o=parseInt(window.getComputedStyle(e).width);new MutationObserver(()=>{if(!document.body.contains(n))return;const e=n.offsetWidth+(i=n,parseInt(window.getComputedStyle(i).marginLeft)+parseInt(window.getComputedStyle(i).marginRight));var i;const s=C();s&&(e>o?s.style.width=`${e}px`:Y(s,"width",t.width))}).observe(n,{attributes:!0,attributeFilter:["style"]})}}),n};const ke=(e,t)=>{const n=k();n&&(J(n),_(n,t,"htmlContainer"),t.html?(ae(t.html,n),X(n,"block")):t.text?(n.textContent=t.text,X(n,"block")):Z(n),((e,t)=>{const n=C();if(!n)return;const o=he.innerParams.get(e),i=!o||t.input!==o.input;ge.forEach(e=>{const o=K(n,r[e]);o&&(be(e,t.inputAttributes),o.className=r[e],i&&Z(o))}),t.input&&(i&&fe(t),ye(t))})(e,t))},Be=(e,t)=>{for(const[n,o]of Object.entries(a))t.icon!==n&&W(e,o);z(e,t.icon&&a[t.icon]),Pe(e,t),$e(),_(e,t,"icon")},$e=()=>{const e=C();if(!e)return;const t=window.getComputedStyle(e).getPropertyValue("background-color"),n=e.querySelectorAll("[class^=swal2-success-circular-line], .swal2-success-fix");for(let e=0;e<n.length;e++)n[e].style.backgroundColor=t},Le=(e,t)=>{if(!t.icon&&!t.iconHtml)return;let n=e.innerHTML,o="";if(t.iconHtml)o=xe(t.iconHtml);else if("success"===t.icon)o=(e=>`\n ${e.animation?'<div class="swal2-success-circular-line-left"></div>':""}\n <span class="swal2-success-line-tip"></span> <span class="swal2-success-line-long"></span>\n <div class="swal2-success-ring"></div>\n ${e.animation?'<div class="swal2-success-fix"></div>':""}\n ${e.animation?'<div class="swal2-success-circular-line-right"></div>':""}\n`)(t),n=n.replace(/ style=".*?"/g,"");else if("error"===t.icon)o='\n <span class="swal2-x-mark">\n <span class="swal2-x-mark-line-left"></span>\n <span class="swal2-x-mark-line-right"></span>\n </span>\n';else if(t.icon){o=xe({question:"?",warning:"!",info:"i"}[t.icon])}n.trim()!==o.trim()&&q(e,o)},Pe=(e,t)=>{if(t.iconColor){e.style.color=t.iconColor,e.style.borderColor=t.iconColor;for(const n of[".swal2-success-line-tip",".swal2-success-line-long",".swal2-x-mark-line-left",".swal2-x-mark-line-right"])G(e,n,"background-color",t.iconColor);G(e,".swal2-success-ring","border-color",t.iconColor)}},xe=e=>`<div class="${r["icon-content"]}">${e}</div>`;let Te=!1,Se=0,Oe=0,Me=0,je=0;const He=e=>{const t=C();if(!t)return;const n=A();if(e.target===t||n&&n.contains(e.target)){Te=!0;const n=Ve(e);Se=n.clientX,Oe=n.clientY,Me=parseInt(t.style.insetInlineStart)||0,je=parseInt(t.style.insetBlockStart)||0,z(t,"swal2-dragging")}},Ie=e=>{const t=C();if(t&&Te){let{clientX:n,clientY:i}=Ve(e);const s=n-Se;t.style.insetInlineStart=`${Me+(o.isRTL?-s:s)}px`,t.style.insetBlockStart=`${je+(i-Oe)}px`}},De=()=>{const e=C();Te=!1,W(e,"swal2-dragging")},Ve=e=>{let t=0,n=0;return e.type.startsWith("mouse")?(t=e.clientX,n=e.clientY):e.type.startsWith("touch")&&(t=e.touches[0].clientX,n=e.touches[0].clientY),{clientX:t,clientY:n}},qe=(e,t)=>{const n=y(),o=C();if(n&&o){if(t.toast){Y(n,"width",t.width),o.style.width="100%";const e=S();e&&o.insertBefore(e,A())}else Y(o,"width",t.width);Y(o,"padding",t.padding),t.color&&(o.style.color=t.color),t.background&&(o.style.background=t.background),Z(L()),Ne(o,t),t.draggable&&!t.toast?(z(o,r.draggable),(e=>{e.addEventListener("mousedown",He),document.body.addEventListener("mousemove",Ie),e.addEventListener("mouseup",De),e.addEventListener("touchstart",He),document.body.addEventListener("touchmove",Ie),e.addEventListener("touchend",De)})(o)):(W(o,r.draggable),(e=>{e.removeEventListener("mousedown",He),document.body.removeEventListener("mousemove",Ie),e.removeEventListener("mouseup",De),e.removeEventListener("touchstart",He),document.body.removeEventListener("touchmove",Ie),e.removeEventListener("touchend",De)})(o))}},Ne=(e,t)=>{const n=t.showClass||{};e.className=`${r.popup} ${ee(e)?n.popup:""}`,t.toast?(z([document.documentElement,document.body],r["toast-shown"]),z(e,r.toast)):z(e,r.modal),_(e,t,"popup"),"string"==typeof t.customClass&&z(e,t.customClass),t.icon&&z(e,r[`icon-${t.icon}`])},_e=e=>{const t=document.createElement("li");return z(t,r["progress-step"]),q(t,e),t},Re=e=>{const t=document.createElement("li");return z(t,r["progress-step-line"]),e.progressStepsDistance&&Y(t,"width",e.progressStepsDistance),t},Fe=(e,t)=>{var n;qe(0,t),me(0,t),((e,t)=>{const n=$();if(!n)return;const{progressSteps:o,currentProgressStep:i}=t;o&&0!==o.length&&void 0!==i?(X(n),n.textContent="",i>=o.length&&u("Invalid currentProgressStep parameter, it should be less than progressSteps.length (currentProgressStep like JS arrays starts from 0)"),o.forEach((e,s)=>{const a=_e(e);if(n.appendChild(a),s===i&&z(a,r["active-progress-step"]),s!==o.length-1){const e=Re(t);n.appendChild(e)}})):Z(n)})(0,t),((e,t)=>{const n=he.innerParams.get(e),o=A();if(!o)return;if(n&&t.icon===n.icon)return Le(o,t),void Be(o,t);if(!t.icon&&!t.iconHtml)return void Z(o);if(t.icon&&-1===Object.keys(a).indexOf(t.icon))return d(`Unknown icon! Expected "success", "error", "warning", "info" or "question", got "${t.icon}"`),void Z(o);X(o),Le(o,t),Be(o,t),z(o,t.showClass&&t.showClass.icon),window.matchMedia("(prefers-color-scheme: dark)").addEventListener("change",$e)})(e,t),((e,t)=>{const n=B();n&&(t.imageUrl?(X(n,""),n.setAttribute("src",t.imageUrl),n.setAttribute("alt",t.imageAlt||""),Y(n,"width",t.imageWidth),Y(n,"height",t.imageHeight),n.className=r.image,_(n,t,"image")):Z(n))})(0,t),((e,t)=>{const n=E();n&&(J(n),Q(n,Boolean(t.title||t.titleText),"block"),t.title&&ae(t.title,n),t.titleText&&(n.innerText=t.titleText),_(n,t,"title"))})(0,t),((e,t)=>{const n=H();n&&(q(n,t.closeButtonHtml||""),_(n,t,"closeButton"),Q(n,t.showCloseButton),n.setAttribute("aria-label",t.closeButtonAriaLabel||""))})(0,t),ke(e,t),ue(0,t),((e,t)=>{const n=M();n&&(J(n),Q(n,Boolean(t.footer),"block"),t.footer&&ae(t.footer,n),_(n,t,"footer"))})(0,t);const i=C();"function"==typeof t.didRender&&i&&t.didRender(i),null===(n=o.eventEmitter)||void 0===n||n.emit("didRender",i)},Ue=()=>{var e;return null===(e=P())||void 0===e?void 0:e.click()},ze=Object.freeze({cancel:"cancel",backdrop:"backdrop",close:"close",esc:"esc",timer:"timer"}),We=e=>{if(e.keydownTarget&&e.keydownHandlerAdded&&e.keydownHandler){const t=e.keydownHandler;e.keydownTarget.removeEventListener("keydown",t,{capture:e.keydownListenerCapture}),e.keydownHandlerAdded=!1}},Ke=(e,t)=>{var n;const o=I();if(o.length)return-2===(e+=t)&&(e=o.length-1),e===o.length?e=0:-1===e&&(e=o.length-1),void o[e].focus();null===(n=C())||void 0===n||n.focus()},Ye=["ArrowRight","ArrowDown"],Xe=["ArrowLeft","ArrowUp"],Ze=(e,t,n)=>{e&&(t.isComposing||229===t.keyCode||(e.stopKeydownPropagation&&t.stopPropagation(),"Enter"===t.key?Je(t,e):"Tab"===t.key?Ge(t):[...Ye,...Xe].includes(t.key)?Qe(t.key):"Escape"===t.key&&et(t,e,n)))},Je=(e,t)=>{if(!h(t.allowEnterKey))return;const n=C();if(!n||!t.input)return;const o=R(n,t.input);if(e.target&&o&&e.target instanceof HTMLElement&&e.target.outerHTML===o.outerHTML){if(["textarea","file"].includes(t.input))return;Ue(),e.preventDefault()}},Ge=e=>{const t=e.target,n=I();let o=-1;for(let e=0;e<n.length;e++)if(t===n[e]){o=e;break}e.shiftKey?Ke(o,-1):Ke(o,1),e.stopPropagation(),e.preventDefault()},Qe=e=>{const t=O(),n=P(),o=T(),i=x();if(!(t&&n&&o&&i))return;const s=[n,o,i];if(document.activeElement instanceof HTMLElement&&!s.includes(document.activeElement))return;const r=Ye.includes(e)?"nextElementSibling":"previousElementSibling";let a=document.activeElement;if(a){for(let e=0;e<t.children.length;e++){if(a=a[r],!a)return;if(a instanceof HTMLButtonElement&&ee(a))break}a instanceof HTMLButtonElement&&a.focus()}},et=(e,t,n)=>{e.preventDefault(),h(t.allowEscapeKey)&&n(ze.esc)};var tt={swalPromiseResolve:new WeakMap,swalPromiseReject:new WeakMap};const nt=()=>{Array.from(document.body.children).forEach(e=>{e.hasAttribute("data-previous-aria-hidden")?(e.setAttribute("aria-hidden",e.getAttribute("data-previous-aria-hidden")||""),e.removeAttribute("data-previous-aria-hidden")):e.removeAttribute("aria-hidden")})},ot="undefined"!=typeof window&&Boolean(window.GestureEvent),it=()=>{const e=y();if(!e)return;let t;e.ontouchstart=e=>{t=st(e)},e.ontouchmove=e=>{t&&(e.preventDefault(),e.stopPropagation())}},st=e=>{const t=e.target,n=y(),o=k();return!(!n||!o)&&(!rt(e)&&!at(e)&&(t===n||!(te(n)||!(t instanceof HTMLElement)||((e,t)=>{let n=e;for(;n&&n!==t;){if(te(n))return!0;n=n.parentElement}return!1})(t,o)||"INPUT"===t.tagName||"TEXTAREA"===t.tagName||te(o)&&o.contains(t))))},rt=e=>Boolean(e.touches&&e.touches.length&&"stylus"===e.touches[0].touchType),at=e=>e.touches&&e.touches.length>1;let lt=null;const ct=e=>{null===lt&&(document.body.scrollHeight>window.innerHeight||"scroll"===e)&&(lt=parseInt(window.getComputedStyle(document.body).getPropertyValue("padding-right")),document.body.style.paddingRight=`${lt+(()=>{const e=document.createElement("div");e.className=r["scrollbar-measure"],document.body.appendChild(e);const t=e.getBoundingClientRect().width-e.clientWidth;return document.body.removeChild(e),t})()}px`)};function ut(e,t,n,s){V()?yt(e,s):(i(n).then(()=>yt(e,s)),We(o)),ot?(t.setAttribute("style","display:none !important"),t.removeAttribute("class"),t.innerHTML=""):t.remove(),D()&&(null!==lt&&(document.body.style.paddingRight=`${lt}px`,lt=null),(()=>{if(N(document.body,r.iosfix)){const e=parseInt(document.body.style.top,10);W(document.body,r.iosfix),document.body.style.top="",document.body.scrollTop=-1*e}})(),nt()),W([document.documentElement,document.body],[r.shown,r["height-auto"],r["no-backdrop"],r["toast-shown"]])}function dt(e){e=gt(e);const t=tt.swalPromiseResolve.get(this),n=pt(this);this.isAwaitingPromise?e.isDismissed||(ht(this),t(e)):n&&t(e)}const pt=e=>{const t=C();if(!t)return!1;const n=he.innerParams.get(e);if(!n||N(t,n.hideClass.popup))return!1;W(t,n.showClass.popup),z(t,n.hideClass.popup);const o=y();return W(o,n.showClass.backdrop),z(o,n.hideClass.backdrop),ft(e,t,n),!0};function mt(e){const t=tt.swalPromiseReject.get(this);ht(this),t&&t(e)}const ht=e=>{e.isAwaitingPromise&&(delete e.isAwaitingPromise,he.innerParams.get(e)||e._destroy())},gt=e=>void 0===e?{isConfirmed:!1,isDenied:!1,isDismissed:!0}:Object.assign({isConfirmed:!1,isDenied:!1,isDismissed:!1},e),ft=(e,t,n)=>{var i;const s=y(),r=ne(t);"function"==typeof n.willClose&&n.willClose(t),null===(i=o.eventEmitter)||void 0===i||i.emit("willClose",t),r&&s?bt(e,t,s,Boolean(n.returnFocus),n.didClose):s&&ut(e,s,Boolean(n.returnFocus),n.didClose)},bt=(e,t,n,i,s)=>{o.swalCloseEventFinishedCallback=ut.bind(null,e,n,i,s);const r=function(e){var n;e.target===t&&(null===(n=o.swalCloseEventFinishedCallback)||void 0===n||n.call(o),delete o.swalCloseEventFinishedCallback,t.removeEventListener("animationend",r),t.removeEventListener("transitionend",r))};t.addEventListener("animationend",r),t.addEventListener("transitionend",r)},yt=(e,t)=>{setTimeout(()=>{var n;"function"==typeof t&&t.bind(e.params)(),null===(n=o.eventEmitter)||void 0===n||n.emit("didClose"),e._destroy&&e._destroy()})},vt=e=>{let t=C();if(t||new Qn,t=C(),!t)return;const n=S();V()?Z(A()):wt(t,e),X(n),t.setAttribute("data-loading","true"),t.setAttribute("aria-busy","true"),t.focus()},wt=(e,t)=>{const n=O(),o=S();n&&o&&(!t&&ee(P())&&(t=P()),X(n),t&&(Z(t),o.setAttribute("data-button-to-replace",t.className),n.insertBefore(o,t)),z([e,n],r.loading))},Ct=e=>e.checked?1:0,At=e=>e.checked?e.value:null,Et=e=>e.files&&e.files.length?null!==e.getAttribute("multiple")?e.files:e.files[0]:null,kt=(e,t)=>{const n=C();if(!n)return;const o=e=>{"select"===t.input?function(e,t,n){const o=K(e,r.select);if(!o)return;const i=(e,t,o)=>{const i=document.createElement("option");i.value=o,q(i,t),i.selected=Lt(o,n.inputValue),e.appendChild(i)};t.forEach(e=>{const t=e[0],n=e[1];if(Array.isArray(n)){const e=document.createElement("optgroup");e.label=t,e.disabled=!1,o.appendChild(e),n.forEach(t=>i(e,t[1],t[0]))}else i(o,n,t)}),o.focus()}(n,$t(e),t):"radio"===t.input&&function(e,t,n){const o=K(e,r.radio);if(!o)return;t.forEach(e=>{const t=e[0],i=e[1],s=document.createElement("input"),a=document.createElement("label");s.type="radio",s.name=r.radio,s.value=t,Lt(t,n.inputValue)&&(s.checked=!0);const l=document.createElement("span");q(l,i),l.className=r.label,a.appendChild(s),a.appendChild(l),o.appendChild(a)});const i=o.querySelectorAll("input");i.length&&i[0].focus()}(n,$t(e),t)};g(t.inputOptions)||b(t.inputOptions)?(vt(P()),f(t.inputOptions).then(t=>{e.hideLoading(),o(t)})):"object"==typeof t.inputOptions?o(t.inputOptions):d("Unexpected type of inputOptions! Expected object, Map or Promise, got "+typeof t.inputOptions)},Bt=(e,t)=>{const n=e.getInput();n&&(Z(n),f(t.inputValue).then(o=>{n.value="number"===t.input?`${parseFloat(o)||0}`:`${o}`,X(n),n.focus(),e.hideLoading()}).catch(t=>{d(`Error in inputValue promise: ${t}`),n.value="",X(n),n.focus(),e.hideLoading()}))};const $t=e=>{const t=[];return e instanceof Map?e.forEach((e,n)=>{let o=e;"object"==typeof o&&(o=$t(o)),t.push([n,o])}):Object.keys(e).forEach(n=>{let o=e[n];"object"==typeof o&&(o=$t(o)),t.push([n,o])}),t},Lt=(e,t)=>Boolean(t)&&null!=t&&t.toString()===e.toString(),Pt=(e,t)=>{const n=he.innerParams.get(e);if(!n.input)return void d(`The "input" parameter is needed to be set when using returnInputValueOn${c(t)}`);const o=e.getInput(),i=((e,t)=>{const n=e.getInput();if(!n)return null;switch(t.input){case"checkbox":return Ct(n);case"radio":return At(n);case"file":return Et(n);default:return t.inputAutoTrim?n.value.trim():n.value}})(e,n);n.inputValidator?xt(e,i,t):o&&!o.checkValidity()?(e.enableButtons(),e.showValidationMessage(n.validationMessage||o.validationMessage)):"deny"===t?Tt(e,i):Mt(e,i)},xt=(e,t,n)=>{const o=he.innerParams.get(e);e.disableInput();Promise.resolve().then(()=>f(o.inputValidator(t,o.validationMessage))).then(o=>{e.enableButtons(),e.enableInput(),o?e.showValidationMessage(o):"deny"===n?Tt(e,t):Mt(e,t)})},Tt=(e,t)=>{const n=he.innerParams.get(e);if(n.showLoaderOnDeny&&vt(T()),n.preDeny){e.isAwaitingPromise=!0;Promise.resolve().then(()=>f(n.preDeny(t,n.validationMessage))).then(n=>{!1===n?(e.hideLoading(),ht(e)):e.close({isDenied:!0,value:void 0===n?t:n})}).catch(t=>Ot(e,t))}else e.close({isDenied:!0,value:t})},St=(e,t)=>{e.close({isConfirmed:!0,value:t})},Ot=(e,t)=>{e.rejectPromise(t)},Mt=(e,t)=>{const n=he.innerParams.get(e);if(n.showLoaderOnConfirm&&vt(),n.preConfirm){e.resetValidationMessage(),e.isAwaitingPromise=!0;Promise.resolve().then(()=>f(n.preConfirm(t,n.validationMessage))).then(n=>{ee(L())||!1===n?(e.hideLoading(),ht(e)):St(e,void 0===n?t:n)}).catch(t=>Ot(e,t))}else St(e,t)};function jt(){const e=he.innerParams.get(this);if(!e)return;const t=he.domCache.get(this);Z(t.loader),V()?e.icon&&X(A()):Ht(t),W([t.popup,t.actions],r.loading),t.popup.removeAttribute("aria-busy"),t.popup.removeAttribute("data-loading"),t.confirmButton.disabled=!1,t.denyButton.disabled=!1,t.cancelButton.disabled=!1}const Ht=e=>{const t=e.loader.getAttribute("data-button-to-replace"),n=t?e.popup.getElementsByClassName(t):[];n.length?X(n[0],"inline-block"):ee(P())||ee(T())||ee(x())||Z(e.actions)};function It(){const e=he.innerParams.get(this),t=he.domCache.get(this);return t?R(t.popup,e.input):null}function Dt(e,t,n){const o=he.domCache.get(e);t.forEach(e=>{o[e].disabled=n})}function Vt(e,t){const n=C();if(n&&e)if("radio"===e.type){const e=n.querySelectorAll(`[name="${r.radio}"]`);for(let n=0;n<e.length;n++)e[n].disabled=t}else e.disabled=t}function qt(){Dt(this,["confirmButton","denyButton","cancelButton"],!1)}function Nt(){Dt(this,["confirmButton","denyButton","cancelButton"],!0)}function _t(){Vt(this.getInput(),!1)}function Rt(){Vt(this.getInput(),!0)}function Ft(e){const t=he.domCache.get(this),n=he.innerParams.get(this);q(t.validationMessage,e),t.validationMessage.className=r["validation-message"],n.customClass&&n.customClass.validationMessage&&z(t.validationMessage,n.customClass.validationMessage),X(t.validationMessage);const o=this.getInput();o&&(o.setAttribute("aria-invalid","true"),o.setAttribute("aria-describedby",r["validation-message"]),F(o),z(o,r.inputerror))}function Ut(){const e=he.domCache.get(this);e.validationMessage&&Z(e.validationMessage);const t=this.getInput();t&&(t.removeAttribute("aria-invalid"),t.removeAttribute("aria-describedby"),W(t,r.inputerror))}const zt={title:"",titleText:"",text:"",html:"",footer:"",icon:void 0,iconColor:void 0,iconHtml:void 0,template:void 0,toast:!1,draggable:!1,animation:!0,theme:"light",showClass:{popup:"swal2-show",backdrop:"swal2-backdrop-show",icon:"swal2-icon-show"},hideClass:{popup:"swal2-hide",backdrop:"swal2-backdrop-hide",icon:"swal2-icon-hide"},customClass:{},target:"body",color:void 0,backdrop:!0,heightAuto:!0,allowOutsideClick:!0,allowEscapeKey:!0,allowEnterKey:!0,stopKeydownPropagation:!0,keydownListenerCapture:!1,showConfirmButton:!0,showDenyButton:!1,showCancelButton:!1,preConfirm:void 0,preDeny:void 0,confirmButtonText:"OK",confirmButtonAriaLabel:"",confirmButtonColor:void 0,denyButtonText:"No",denyButtonAriaLabel:"",denyButtonColor:void 0,cancelButtonText:"Cancel",cancelButtonAriaLabel:"",cancelButtonColor:void 0,buttonsStyling:!0,reverseButtons:!1,focusConfirm:!0,focusDeny:!1,focusCancel:!1,returnFocus:!0,showCloseButton:!1,closeButtonHtml:"×",closeButtonAriaLabel:"Close this dialog",loaderHtml:"",showLoaderOnConfirm:!1,showLoaderOnDeny:!1,imageUrl:void 0,imageWidth:void 0,imageHeight:void 0,imageAlt:"",timer:void 0,timerProgressBar:!1,width:void 0,padding:void 0,background:void 0,input:void 0,inputPlaceholder:"",inputLabel:"",inputValue:"",inputOptions:{},inputAutoFocus:!0,inputAutoTrim:!0,inputAttributes:{},inputValidator:void 0,returnInputValueOnDeny:!1,validationMessage:void 0,grow:!1,position:"center",progressSteps:[],currentProgressStep:void 0,progressStepsDistance:void 0,willOpen:void 0,didOpen:void 0,didRender:void 0,willClose:void 0,didClose:void 0,didDestroy:void 0,scrollbarPadding:!0,topLayer:!1},Wt=["allowEscapeKey","allowOutsideClick","background","buttonsStyling","cancelButtonAriaLabel","cancelButtonColor","cancelButtonText","closeButtonAriaLabel","closeButtonHtml","color","confirmButtonAriaLabel","confirmButtonColor","confirmButtonText","currentProgressStep","customClass","denyButtonAriaLabel","denyButtonColor","denyButtonText","didClose","didDestroy","draggable","footer","hideClass","html","icon","iconColor","iconHtml","imageAlt","imageHeight","imageUrl","imageWidth","preConfirm","preDeny","progressSteps","returnFocus","reverseButtons","showCancelButton","showCloseButton","showConfirmButton","showDenyButton","text","title","titleText","theme","willClose"],Kt={allowEnterKey:void 0},Yt=["allowOutsideClick","allowEnterKey","backdrop","draggable","focusConfirm","focusDeny","focusCancel","returnFocus","heightAuto","keydownListenerCapture"],Xt=e=>Object.prototype.hasOwnProperty.call(zt,e),Zt=e=>-1!==Wt.indexOf(e),Jt=e=>Kt[e],Gt=e=>{Xt(e)||u(`Unknown parameter "${e}"`)},Qt=e=>{Yt.includes(e)&&u(`The parameter "${e}" is incompatible with toasts`)},en=e=>{const t=Jt(e);t&&m(e,t)},tn=e=>{!1===e.backdrop&&e.allowOutsideClick&&u('"allowOutsideClick" parameter requires `backdrop` parameter to be set to `true`'),e.theme&&!["light","dark","auto","minimal","borderless","bootstrap-4","bootstrap-4-light","bootstrap-4-dark","bootstrap-5","bootstrap-5-light","bootstrap-5-dark","material-ui","material-ui-light","material-ui-dark","embed-iframe","bulma","bulma-light","bulma-dark"].includes(e.theme)&&u(`Invalid theme "${e.theme}"`);for(const t in e)Gt(t),e.toast&&Qt(t),en(t)};function nn(e){const t=y(),n=C(),o=he.innerParams.get(this);if(!n||N(n,o.hideClass.popup))return void u("You're trying to update the closed or closing popup, that won't work. Use the update() method in preConfirm parameter or show a new popup.");const i=on(e),s=Object.assign({},o,i);tn(s),t&&(t.dataset.swal2Theme=s.theme),Fe(this,s),he.innerParams.set(this,s),Object.defineProperties(this,{params:{value:Object.assign({},this.params,e),writable:!1,enumerable:!0}})}const on=e=>{const t={};return Object.keys(e).forEach(n=>{if(Zt(n)){const o=e;t[n]=o[n]}else u(`Invalid parameter to update: ${n}`)}),t};function sn(){var e;const t=he.domCache.get(this),n=he.innerParams.get(this);n?(t.popup&&o.swalCloseEventFinishedCallback&&(o.swalCloseEventFinishedCallback(),delete o.swalCloseEventFinishedCallback),"function"==typeof n.didDestroy&&n.didDestroy(),null===(e=o.eventEmitter)||void 0===e||e.emit("didDestroy"),rn(this)):an(this)}const rn=e=>{an(e),delete e.params,delete o.keydownHandler,delete o.keydownTarget,delete o.currentInstance},an=e=>{e.isAwaitingPromise?(ln(he,e),e.isAwaitingPromise=!0):(ln(tt,e),ln(he,e),delete e.isAwaitingPromise,delete e.disableButtons,delete e.enableButtons,delete e.getInput,delete e.disableInput,delete e.enableInput,delete e.hideLoading,delete e.disableLoading,delete e.showValidationMessage,delete e.resetValidationMessage,delete e.close,delete e.closePopup,delete e.closeModal,delete e.closeToast,delete e.rejectPromise,delete e.update,delete e._destroy)},ln=(e,t)=>{for(const n in e)e[n].delete(t)};var cn=Object.freeze({__proto__:null,_destroy:sn,close:dt,closeModal:dt,closePopup:dt,closeToast:dt,disableButtons:Nt,disableInput:Rt,disableLoading:jt,enableButtons:qt,enableInput:_t,getInput:It,handleAwaitingPromise:ht,hideLoading:jt,rejectPromise:mt,resetValidationMessage:Ut,showValidationMessage:Ft,update:nn});const un=(e,t,n)=>{t.popup.onclick=()=>{e&&(dn(e)||e.timer||e.input)||n(ze.close)}},dn=e=>Boolean(e.showConfirmButton||e.showDenyButton||e.showCancelButton||e.showCloseButton);let pn=!1;const mn=e=>{e.popup.onmousedown=()=>{e.container.onmouseup=function(t){e.container.onmouseup=()=>{},t.target===e.container&&(pn=!0)}}},hn=e=>{e.container.onmousedown=t=>{t.target===e.container&&t.preventDefault(),e.popup.onmouseup=function(t){e.popup.onmouseup=()=>{},(t.target===e.popup||t.target instanceof HTMLElement&&e.popup.contains(t.target))&&(pn=!0)}}},gn=(e,t,n)=>{t.container.onclick=o=>{pn?pn=!1:o.target===t.container&&h(e.allowOutsideClick)&&n(ze.backdrop)}},fn=e=>e instanceof Element||(e=>"object"==typeof e&&e.jquery)(e);const bn=()=>{if(o.timeout)return(()=>{const e=j();if(!e)return;const t=parseInt(window.getComputedStyle(e).width);e.style.removeProperty("transition"),e.style.width="100%";const n=t/parseInt(window.getComputedStyle(e).width)*100;e.style.width=`${n}%`})(),o.timeout.stop()},yn=()=>{if(o.timeout){const e=o.timeout.start();return oe(e),e}};let vn=!1;const wn={};const Cn=e=>{for(let t=e.target;t&&t!==document;t=t.parentNode)for(const e in wn){const n=t.getAttribute&&t.getAttribute(e);if(n)return void wn[e].fire({template:n})}};o.eventEmitter=new class{constructor(){this.events={}}_getHandlersByEventName(e){return void 0===this.events[e]&&(this.events[e]=[]),this.events[e]}on(e,t){const n=this._getHandlersByEventName(e);n.includes(t)||n.push(t)}once(e,t){const n=(...o)=>{this.removeListener(e,n),t.apply(this,o)};this.on(e,n)}emit(e,...t){this._getHandlersByEventName(e).forEach(e=>{try{e.apply(this,t)}catch(e){console.error(e)}})}removeListener(e,t){const n=this._getHandlersByEventName(e),o=n.indexOf(t);o>-1&&n.splice(o,1)}removeAllListeners(e){void 0!==this.events[e]&&(this.events[e].length=0)}reset(){this.events={}}};var An=Object.freeze({__proto__:null,argsToParams:e=>{const t={};return"object"!=typeof e[0]||fn(e[0])?["title","html","icon"].forEach((n,o)=>{const i=e[o];"string"==typeof i||fn(i)?t[n]=i:void 0!==i&&d(`Unexpected type of ${n}! Expected "string" or "Element", got ${typeof i}`)}):Object.assign(t,e[0]),t},bindClickHandler:function(e="data-swal-template"){wn[e]=this,vn||(document.body.addEventListener("click",Cn),vn=!0)},clickCancel:()=>{var e;return null===(e=x())||void 0===e?void 0:e.click()},clickConfirm:Ue,clickDeny:()=>{var e;return null===(e=T())||void 0===e?void 0:e.click()},enableLoading:vt,fire:function(...e){return new this(...e)},getActions:O,getCancelButton:x,getCloseButton:H,getConfirmButton:P,getContainer:y,getDenyButton:T,getFocusableElements:I,getFooter:M,getHtmlContainer:k,getIcon:A,getIconContent:()=>w(r["icon-content"]),getImage:B,getInputLabel:()=>w(r["input-label"]),getLoader:S,getPopup:C,getProgressSteps:$,getTimerLeft:()=>o.timeout&&o.timeout.getTimerLeft(),getTimerProgressBar:j,getTitle:E,getValidationMessage:L,increaseTimer:e=>{if(o.timeout){const t=o.timeout.increase(e);return oe(t,!0),t}},isDeprecatedParameter:Jt,isLoading:()=>{const e=C();return!!e&&e.hasAttribute("data-loading")},isTimerRunning:()=>Boolean(o.timeout&&o.timeout.isRunning()),isUpdatableParameter:Zt,isValidParameter:Xt,isVisible:()=>ee(C()),mixin:function(e){return class extends(this){_main(t,n){return super._main(t,Object.assign({},e,n))}}},off:(e,t)=>{o.eventEmitter&&(e?t?o.eventEmitter.removeListener(e,t):o.eventEmitter.removeAllListeners(e):o.eventEmitter.reset())},on:(e,t)=>{o.eventEmitter&&o.eventEmitter.on(e,t)},once:(e,t)=>{o.eventEmitter&&o.eventEmitter.once(e,t)},resumeTimer:yn,showLoading:vt,stopTimer:bn,toggleTimer:()=>{const e=o.timeout;return e&&(e.running?bn():yn())}});class En{constructor(e,t){this.callback=e,this.remaining=t,this.running=!1,this.start()}start(){return this.running||(this.running=!0,this.started=new Date,this.id=setTimeout(this.callback,this.remaining)),this.remaining}stop(){return this.started&&this.running&&(this.running=!1,clearTimeout(this.id),this.remaining-=(new Date).getTime()-this.started.getTime()),this.remaining}increase(e){const t=this.running;return t&&this.stop(),this.remaining+=e,t&&this.start(),this.remaining}getTimerLeft(){return this.running&&(this.stop(),this.start()),this.remaining}isRunning(){return this.running}}const kn=["swal-title","swal-html","swal-footer"],Bn=e=>{const t={};return Array.from(e.querySelectorAll("swal-param")).forEach(e=>{Mn(e,["name","value"]);const n=e.getAttribute("name"),o=e.getAttribute("value");n&&o&&(t[n]=n in zt&&"boolean"==typeof zt[n]?"false"!==o:n in zt&&"object"==typeof zt[n]?JSON.parse(o):o)}),t},$n=e=>{const t={};return Array.from(e.querySelectorAll("swal-function-param")).forEach(e=>{const n=e.getAttribute("name"),o=e.getAttribute("value");n&&o&&(t[n]=new Function(`return ${o}`)())}),t},Ln=e=>{const t={};return Array.from(e.querySelectorAll("swal-button")).forEach(e=>{Mn(e,["type","color","aria-label"]);const n=e.getAttribute("type");if(n&&["confirm","cancel","deny"].includes(n)){if(t[`${n}ButtonText`]=e.innerHTML,t[`show${c(n)}Button`]=!0,e.hasAttribute("color")){const o=e.getAttribute("color");null!==o&&(t[`${n}ButtonColor`]=o)}if(e.hasAttribute("aria-label")){const o=e.getAttribute("aria-label");null!==o&&(t[`${n}ButtonAriaLabel`]=o)}}}),t},Pn=e=>{const t={},n=e.querySelector("swal-image");return n&&(Mn(n,["src","width","height","alt"]),n.hasAttribute("src")&&(t.imageUrl=n.getAttribute("src")||void 0),n.hasAttribute("width")&&(t.imageWidth=n.getAttribute("width")||void 0),n.hasAttribute("height")&&(t.imageHeight=n.getAttribute("height")||void 0),n.hasAttribute("alt")&&(t.imageAlt=n.getAttribute("alt")||void 0)),t},xn=e=>{const t={},n=e.querySelector("swal-icon");return n&&(Mn(n,["type","color"]),n.hasAttribute("type")&&(t.icon=n.getAttribute("type")),n.hasAttribute("color")&&(t.iconColor=n.getAttribute("color")),t.iconHtml=n.innerHTML),t},Tn=e=>{const t={},n=e.querySelector("swal-input");n&&(Mn(n,["type","label","placeholder","value"]),t.input=n.getAttribute("type")||"text",n.hasAttribute("label")&&(t.inputLabel=n.getAttribute("label")),n.hasAttribute("placeholder")&&(t.inputPlaceholder=n.getAttribute("placeholder")),n.hasAttribute("value")&&(t.inputValue=n.getAttribute("value")));const o=Array.from(e.querySelectorAll("swal-input-option"));return o.length&&(t.inputOptions={},o.forEach(e=>{Mn(e,["value"]);const n=e.getAttribute("value");if(!n)return;const o=e.innerHTML;t.inputOptions[n]=o})),t},Sn=(e,t)=>{const n={};for(const o in t){const i=t[o],s=e.querySelector(i);s&&(Mn(s,[]),n[i.replace(/^swal-/,"")]=s.innerHTML.trim())}return n},On=e=>{const t=kn.concat(["swal-param","swal-function-param","swal-button","swal-image","swal-icon","swal-input","swal-input-option"]);Array.from(e.children).forEach(e=>{const n=e.tagName.toLowerCase();t.includes(n)||u(`Unrecognized element <${n}>`)})},Mn=(e,t)=>{Array.from(e.attributes).forEach(n=>{-1===t.indexOf(n.name)&&u([`Unrecognized attribute "${n.name}" on <${e.tagName.toLowerCase()}>.`,""+(t.length?`Allowed attributes are: ${t.join(", ")}`:"To set the value, use HTML within the element.")])})},jn=e=>{var t,n;const i=y(),s=C();if(!i||!s)return;"function"==typeof e.willOpen&&e.willOpen(s),null===(t=o.eventEmitter)||void 0===t||t.emit("willOpen",s);const r=window.getComputedStyle(document.body).overflowY;if(Vn(i,s,e),setTimeout(()=>{In(i,s)},10),D()&&(Dn(i,void 0!==e.scrollbarPadding&&e.scrollbarPadding,r),(()=>{const e=y();Array.from(document.body.children).forEach(t=>{t.contains(e)||(t.hasAttribute("aria-hidden")&&t.setAttribute("data-previous-aria-hidden",t.getAttribute("aria-hidden")||""),t.setAttribute("aria-hidden","true"))})})()),V()||o.previousActiveElement||(o.previousActiveElement=document.activeElement),"function"==typeof e.didOpen){const t=e.didOpen;setTimeout(()=>t(s))}null===(n=o.eventEmitter)||void 0===n||n.emit("didOpen",s)},Hn=e=>{const t=C();if(!t||e.target!==t)return;const n=y();n&&(t.removeEventListener("animationend",Hn),t.removeEventListener("transitionend",Hn),n.style.overflowY="auto",W(n,r["no-transition"]))},In=(e,t)=>{ne(t)?(e.style.overflowY="hidden",t.addEventListener("animationend",Hn),t.addEventListener("transitionend",Hn)):e.style.overflowY="auto"},Dn=(e,t,n)=>{(()=>{if(ot&&!N(document.body,r.iosfix)){const e=document.body.scrollTop;document.body.style.top=-1*e+"px",z(document.body,r.iosfix),it()}})(),t&&"hidden"!==n&&ct(n),setTimeout(()=>{e.scrollTop=0})},Vn=(e,t,n)=>{var o;null!==(o=n.showClass)&&void 0!==o&&o.backdrop&&z(e,n.showClass.backdrop),n.animation?(t.style.setProperty("opacity","0","important"),X(t,"grid"),setTimeout(()=>{var e;null!==(e=n.showClass)&&void 0!==e&&e.popup&&z(t,n.showClass.popup),t.style.removeProperty("opacity")},10)):X(t,"grid"),z([document.documentElement,document.body],r.shown),n.heightAuto&&n.backdrop&&!n.toast&&z([document.documentElement,document.body],r["height-auto"])};var qn=(e,t)=>/^[a-zA-Z0-9.+_'-]+@[a-zA-Z0-9.-]+\.[a-zA-Z0-9-]+$/.test(e)?Promise.resolve():Promise.resolve(t||"Invalid email address"),Nn=(e,t)=>/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-z]{2,63}\b([-a-zA-Z0-9@:%_+.~#?&/=]*)$/.test(e)?Promise.resolve():Promise.resolve(t||"Invalid URL");function _n(e){!function(e){e.inputValidator||("email"===e.input&&(e.inputValidator=qn),"url"===e.input&&(e.inputValidator=Nn))}(e),e.showLoaderOnConfirm&&!e.preConfirm&&u("showLoaderOnConfirm is set to true, but preConfirm is not defined.\nshowLoaderOnConfirm should be used together with preConfirm, see usage example:\nhttps://sweetalert2.github.io/#ajax-request"),function(e){(!e.target||"string"==typeof e.target&&!document.querySelector(e.target)||"string"!=typeof e.target&&!e.target.appendChild)&&(u('Target parameter is not valid, defaulting to "body"'),e.target="body")}(e),"string"==typeof e.title&&(e.title=e.title.split("\n").join("<br />")),re(e)}let Rn;var Fn=new WeakMap;class Un{constructor(...t){if(n(this,Fn,Promise.resolve({isConfirmed:!1,isDenied:!1,isDismissed:!0})),"undefined"==typeof window)return;Rn=this;const o=Object.freeze(this.constructor.argsToParams(t));var i,s,r;this.params=o,this.isAwaitingPromise=!1,i=Fn,s=this,r=this._main(Rn.params),i.set(e(i,s),r)}_main(e,t={}){if(tn(Object.assign({},t,e)),o.currentInstance){const e=tt.swalPromiseResolve.get(o.currentInstance),{isAwaitingPromise:t}=o.currentInstance;o.currentInstance._destroy(),t||e({isDismissed:!0}),D()&&nt()}o.currentInstance=Rn;const n=Wn(e,t);_n(n),Object.freeze(n),o.timeout&&(o.timeout.stop(),delete o.timeout),clearTimeout(o.restoreFocusTimeout);const i=Kn(Rn);return Fe(Rn,n),he.innerParams.set(Rn,n),zn(Rn,i,n)}then(e){return t(Fn,this).then(e)}finally(e){return t(Fn,this).finally(e)}}const zn=(e,t,n)=>new Promise((i,s)=>{const r=t=>{e.close({isDismissed:!0,dismiss:t,isConfirmed:!1,isDenied:!1})};tt.swalPromiseResolve.set(e,i),tt.swalPromiseReject.set(e,s),t.confirmButton.onclick=()=>{(e=>{const t=he.innerParams.get(e);e.disableButtons(),t.input?Pt(e,"confirm"):Mt(e,!0)})(e)},t.denyButton.onclick=()=>{(e=>{const t=he.innerParams.get(e);e.disableButtons(),t.returnInputValueOnDeny?Pt(e,"deny"):Tt(e,!1)})(e)},t.cancelButton.onclick=()=>{((e,t)=>{e.disableButtons(),t(ze.cancel)})(e,r)},t.closeButton.onclick=()=>{r(ze.close)},((e,t,n)=>{e.toast?un(e,t,n):(mn(t),hn(t),gn(e,t,n))})(n,t,r),((e,t,n)=>{if(We(e),!t.toast){const o=e=>Ze(t,e,n);e.keydownHandler=o;const i=t.keydownListenerCapture?window:C();if(i){e.keydownTarget=i,e.keydownListenerCapture=t.keydownListenerCapture;const n=o;e.keydownTarget.addEventListener("keydown",n,{capture:e.keydownListenerCapture}),e.keydownHandlerAdded=!0}}})(o,n,r),((e,t)=>{"select"===t.input||"radio"===t.input?kt(e,t):["text","email","number","tel","textarea"].some(e=>e===t.input)&&(g(t.inputValue)||b(t.inputValue))&&(vt(P()),Bt(e,t))})(e,n),jn(n),Yn(o,n,r),Xn(t,n),setTimeout(()=>{t.container.scrollTop=0})}),Wn=(e,t)=>{const n=(e=>{const t="string"==typeof e.template?document.querySelector(e.template):e.template;if(!t)return{};const n=t.content;return On(n),Object.assign(Bn(n),$n(n),Ln(n),Pn(n),xn(n),Tn(n),Sn(n,kn))})(e),o=Object.assign({},zt,t,n,e);return o.showClass=Object.assign({},zt.showClass,o.showClass),o.hideClass=Object.assign({},zt.hideClass,o.hideClass),!1===o.animation&&(o.showClass={backdrop:"swal2-noanimation"},o.hideClass={}),o},Kn=e=>{const t={popup:C(),container:y(),actions:O(),confirmButton:P(),denyButton:T(),cancelButton:x(),loader:S(),closeButton:H(),validationMessage:L(),progressSteps:$()};return he.domCache.set(e,t),t},Yn=(e,t,n)=>{const o=j();Z(o),t.timer&&(e.timeout=new En(()=>{n("timer"),delete e.timeout},t.timer),t.timerProgressBar&&o&&(X(o),_(o,t,"timerProgressBar"),setTimeout(()=>{e.timeout&&e.timeout.running&&oe(t.timer)})))},Xn=(e,t)=>{if(!t.toast)return h(t.allowEnterKey)?void(Zn(e)||Jn(e,t)||Ke(-1,1)):(m("allowEnterKey"),void Gn())},Zn=e=>{const t=Array.from(e.popup.querySelectorAll("[autofocus]"));for(const e of t)if(e instanceof HTMLElement&&ee(e))return e.focus(),!0;return!1},Jn=(e,t)=>t.focusDeny&&ee(e.denyButton)?(e.denyButton.focus(),!0):t.focusCancel&&ee(e.cancelButton)?(e.cancelButton.focus(),!0):!(!t.focusConfirm||!ee(e.confirmButton))&&(e.confirmButton.focus(),!0),Gn=()=>{document.activeElement instanceof HTMLElement&&"function"==typeof document.activeElement.blur&&document.activeElement.blur()};Un.prototype.disableButtons=Nt,Un.prototype.enableButtons=qt,Un.prototype.getInput=It,Un.prototype.disableInput=Rt,Un.prototype.enableInput=_t,Un.prototype.hideLoading=jt,Un.prototype.disableLoading=jt,Un.prototype.showValidationMessage=Ft,Un.prototype.resetValidationMessage=Ut,Un.prototype.close=dt,Un.prototype.closePopup=dt,Un.prototype.closeModal=dt,Un.prototype.closeToast=dt,Un.prototype.rejectPromise=mt,Un.prototype.update=nn,Un.prototype._destroy=sn,Object.assign(Un,An),Object.keys(cn).forEach(e=>{Un[e]=function(...t){if(Rn&&Rn[e])return Rn[e](...t)}}),Un.DismissReason=ze,Un.version="11.26.17";const Qn=Un;return Qn.default=Qn,Qn}),void 0!==this&&this.Sweetalert2&&(this.swal=this.sweetAlert=this.Swal=this.SweetAlert=this.Sweetalert2);
"undefined"!=typeof document&&function(e,t){var n=e.createElement("style");if(e.getElementsByTagName("head")[0].appendChild(n),n.styleSheet)n.styleSheet.disabled||(n.styleSheet.cssText=t);else try{n.innerHTML=t}catch(e){n.innerText=t}}(document,":root{--swal2-outline: 0 0 0 3px rgba(100, 150, 200, 0.5);--swal2-container-padding: 0.625em;--swal2-backdrop: rgba(0, 0, 0, 0.4);--swal2-backdrop-transition: background-color 0.15s;--swal2-width: 32em;--swal2-padding: 0 0 1.25em;--swal2-border: none;--swal2-border-radius: 0.3125rem;--swal2-background: white;--swal2-color: #545454;--swal2-show-animation: swal2-show 0.3s;--swal2-hide-animation: swal2-hide 0.15s forwards;--swal2-icon-zoom: 1;--swal2-icon-animations: true;--swal2-title-padding: 0.8em 1em 0;--swal2-html-container-padding: 1em 1.6em 0.3em;--swal2-input-border: 1px solid #d9d9d9;--swal2-input-border-radius: 0.1875em;--swal2-input-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.06), 0 0 0 3px transparent;--swal2-input-background: transparent;--swal2-input-transition: border-color 0.2s, box-shadow 0.2s;--swal2-input-hover-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.06), 0 0 0 3px transparent;--swal2-input-focus-border: 1px solid #b4dbed;--swal2-input-focus-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.06), 0 0 0 3px rgba(100, 150, 200, 0.5);--swal2-progress-step-background: #add8e6;--swal2-validation-message-background: #f0f0f0;--swal2-validation-message-color: #666;--swal2-footer-border-color: #eee;--swal2-footer-background: transparent;--swal2-footer-color: inherit;--swal2-timer-progress-bar-background: rgba(0, 0, 0, 0.3);--swal2-close-button-position: initial;--swal2-close-button-inset: auto;--swal2-close-button-font-size: 2.5em;--swal2-close-button-color: #ccc;--swal2-close-button-transition: color 0.2s, box-shadow 0.2s;--swal2-close-button-outline: initial;--swal2-close-button-box-shadow: inset 0 0 0 3px transparent;--swal2-close-button-focus-box-shadow: inset var(--swal2-outline);--swal2-close-button-hover-transform: none;--swal2-actions-justify-content: center;--swal2-actions-width: auto;--swal2-actions-margin: 1.25em auto 0;--swal2-actions-padding: 0;--swal2-actions-border-radius: 0;--swal2-actions-background: transparent;--swal2-action-button-transition: background-color 0.2s, box-shadow 0.2s;--swal2-action-button-hover: black 10%;--swal2-action-button-active: black 10%;--swal2-confirm-button-box-shadow: none;--swal2-confirm-button-border-radius: 0.25em;--swal2-confirm-button-background-color: #7066e0;--swal2-confirm-button-color: #fff;--swal2-deny-button-box-shadow: none;--swal2-deny-button-border-radius: 0.25em;--swal2-deny-button-background-color: #dc3741;--swal2-deny-button-color: #fff;--swal2-cancel-button-box-shadow: none;--swal2-cancel-button-border-radius: 0.25em;--swal2-cancel-button-background-color: #6e7881;--swal2-cancel-button-color: #fff;--swal2-toast-show-animation: swal2-toast-show 0.5s;--swal2-toast-hide-animation: swal2-toast-hide 0.1s forwards;--swal2-toast-border: none;--swal2-toast-box-shadow: 0 0 1px hsl(0deg 0% 0% / 0.075), 0 1px 2px hsl(0deg 0% 0% / 0.075), 1px 2px 4px hsl(0deg 0% 0% / 0.075), 1px 3px 8px hsl(0deg 0% 0% / 0.075), 2px 4px 16px hsl(0deg 0% 0% / 0.075)}[data-swal2-theme=dark]{--swal2-dark-theme-black: #19191a;--swal2-dark-theme-white: #e1e1e1;--swal2-background: var(--swal2-dark-theme-black);--swal2-color: var(--swal2-dark-theme-white);--swal2-footer-border-color: #555;--swal2-input-background: color-mix(in srgb, var(--swal2-dark-theme-black), var(--swal2-dark-theme-white) 10%);--swal2-validation-message-background: color-mix( in srgb, var(--swal2-dark-theme-black), var(--swal2-dark-theme-white) 10% );--swal2-validation-message-color: var(--swal2-dark-theme-white);--swal2-timer-progress-bar-background: rgba(255, 255, 255, 0.7)}@media(prefers-color-scheme: dark){[data-swal2-theme=auto]{--swal2-dark-theme-black: #19191a;--swal2-dark-theme-white: #e1e1e1;--swal2-background: var(--swal2-dark-theme-black);--swal2-color: var(--swal2-dark-theme-white);--swal2-footer-border-color: #555;--swal2-input-background: color-mix(in srgb, var(--swal2-dark-theme-black), var(--swal2-dark-theme-white) 10%);--swal2-validation-message-background: color-mix( in srgb, var(--swal2-dark-theme-black), var(--swal2-dark-theme-white) 10% );--swal2-validation-message-color: var(--swal2-dark-theme-white);--swal2-timer-progress-bar-background: rgba(255, 255, 255, 0.7)}}body.swal2-shown:not(.swal2-no-backdrop,.swal2-toast-shown){overflow:hidden}body.swal2-height-auto{height:auto !important}body.swal2-no-backdrop .swal2-container{background-color:rgba(0,0,0,0) !important;pointer-events:none}body.swal2-no-backdrop .swal2-container .swal2-popup{pointer-events:all}body.swal2-no-backdrop .swal2-container .swal2-modal{box-shadow:0 0 10px var(--swal2-backdrop)}body.swal2-toast-shown .swal2-container{box-sizing:border-box;width:360px;max-width:100%;background-color:rgba(0,0,0,0);pointer-events:none}body.swal2-toast-shown .swal2-container.swal2-top{inset:0 auto auto 50%;transform:translateX(-50%)}body.swal2-toast-shown .swal2-container.swal2-top-end,body.swal2-toast-shown .swal2-container.swal2-top-right{inset:0 0 auto auto}body.swal2-toast-shown .swal2-container.swal2-top-start,body.swal2-toast-shown .swal2-container.swal2-top-left{inset:0 auto auto 0}body.swal2-toast-shown .swal2-container.swal2-center-start,body.swal2-toast-shown .swal2-container.swal2-center-left{inset:50% auto auto 0;transform:translateY(-50%)}body.swal2-toast-shown .swal2-container.swal2-center{inset:50% auto auto 50%;transform:translate(-50%, -50%)}body.swal2-toast-shown .swal2-container.swal2-center-end,body.swal2-toast-shown .swal2-container.swal2-center-right{inset:50% 0 auto auto;transform:translateY(-50%)}body.swal2-toast-shown .swal2-container.swal2-bottom-start,body.swal2-toast-shown .swal2-container.swal2-bottom-left{inset:auto auto 0 0}body.swal2-toast-shown .swal2-container.swal2-bottom{inset:auto auto 0 50%;transform:translateX(-50%)}body.swal2-toast-shown .swal2-container.swal2-bottom-end,body.swal2-toast-shown .swal2-container.swal2-bottom-right{inset:auto 0 0 auto}@media print{body.swal2-shown:not(.swal2-no-backdrop,.swal2-toast-shown){overflow-y:scroll !important}body.swal2-shown:not(.swal2-no-backdrop,.swal2-toast-shown)>[aria-hidden=true]{display:none}body.swal2-shown:not(.swal2-no-backdrop,.swal2-toast-shown) .swal2-container{position:static !important}}div:where(.swal2-container){display:grid;position:fixed;z-index:1060;inset:0;box-sizing:border-box;grid-template-areas:\"top-start top top-end\" \"center-start center center-end\" \"bottom-start bottom-center bottom-end\";grid-template-rows:minmax(min-content, auto) minmax(min-content, auto) minmax(min-content, auto);height:100%;padding:var(--swal2-container-padding);overflow-x:hidden;transition:var(--swal2-backdrop-transition);-webkit-overflow-scrolling:touch}div:where(.swal2-container).swal2-backdrop-show,div:where(.swal2-container).swal2-noanimation{background:var(--swal2-backdrop)}div:where(.swal2-container).swal2-backdrop-hide{background:rgba(0,0,0,0) !important}div:where(.swal2-container).swal2-top-start,div:where(.swal2-container).swal2-center-start,div:where(.swal2-container).swal2-bottom-start{grid-template-columns:minmax(0, 1fr) auto auto}div:where(.swal2-container).swal2-top,div:where(.swal2-container).swal2-center,div:where(.swal2-container).swal2-bottom{grid-template-columns:auto minmax(0, 1fr) auto}div:where(.swal2-container).swal2-top-end,div:where(.swal2-container).swal2-center-end,div:where(.swal2-container).swal2-bottom-end{grid-template-columns:auto auto minmax(0, 1fr)}div:where(.swal2-container).swal2-top-start>.swal2-popup{align-self:start}div:where(.swal2-container).swal2-top>.swal2-popup{grid-column:2;place-self:start center}div:where(.swal2-container).swal2-top-end>.swal2-popup,div:where(.swal2-container).swal2-top-right>.swal2-popup{grid-column:3;place-self:start end}div:where(.swal2-container).swal2-center-start>.swal2-popup,div:where(.swal2-container).swal2-center-left>.swal2-popup{grid-row:2;align-self:center}div:where(.swal2-container).swal2-center>.swal2-popup{grid-column:2;grid-row:2;place-self:center center}div:where(.swal2-container).swal2-center-end>.swal2-popup,div:where(.swal2-container).swal2-center-right>.swal2-popup{grid-column:3;grid-row:2;place-self:center end}div:where(.swal2-container).swal2-bottom-start>.swal2-popup,div:where(.swal2-container).swal2-bottom-left>.swal2-popup{grid-column:1;grid-row:3;align-self:end}div:where(.swal2-container).swal2-bottom>.swal2-popup{grid-column:2;grid-row:3;place-self:end center}div:where(.swal2-container).swal2-bottom-end>.swal2-popup,div:where(.swal2-container).swal2-bottom-right>.swal2-popup{grid-column:3;grid-row:3;place-self:end end}div:where(.swal2-container).swal2-grow-row>.swal2-popup,div:where(.swal2-container).swal2-grow-fullscreen>.swal2-popup{grid-column:1/4;width:100%}div:where(.swal2-container).swal2-grow-column>.swal2-popup,div:where(.swal2-container).swal2-grow-fullscreen>.swal2-popup{grid-row:1/4;align-self:stretch}div:where(.swal2-container).swal2-no-transition{transition:none !important}div:where(.swal2-container)[popover]{width:auto;border:0}div:where(.swal2-container) div:where(.swal2-popup){display:none;position:relative;box-sizing:border-box;grid-template-columns:minmax(0, 100%);width:var(--swal2-width);max-width:100%;padding:var(--swal2-padding);border:var(--swal2-border);border-radius:var(--swal2-border-radius);background:var(--swal2-background);color:var(--swal2-color);font-family:inherit;font-size:1rem;container-name:swal2-popup}div:where(.swal2-container) div:where(.swal2-popup):focus{outline:none}div:where(.swal2-container) div:where(.swal2-popup).swal2-loading{overflow-y:hidden}div:where(.swal2-container) div:where(.swal2-popup).swal2-draggable{cursor:grab}div:where(.swal2-container) div:where(.swal2-popup).swal2-draggable div:where(.swal2-icon){cursor:grab}div:where(.swal2-container) div:where(.swal2-popup).swal2-dragging{cursor:grabbing}div:where(.swal2-container) div:where(.swal2-popup).swal2-dragging div:where(.swal2-icon){cursor:grabbing}div:where(.swal2-container) h2:where(.swal2-title){position:relative;max-width:100%;margin:0;padding:var(--swal2-title-padding);color:inherit;font-size:1.875em;font-weight:600;text-align:center;text-transform:none;overflow-wrap:break-word;cursor:initial}div:where(.swal2-container) div:where(.swal2-actions){display:flex;z-index:1;box-sizing:border-box;flex-wrap:wrap;align-items:center;justify-content:var(--swal2-actions-justify-content);width:var(--swal2-actions-width);margin:var(--swal2-actions-margin);padding:var(--swal2-actions-padding);border-radius:var(--swal2-actions-border-radius);background:var(--swal2-actions-background)}div:where(.swal2-container) div:where(.swal2-loader){display:none;align-items:center;justify-content:center;width:2.2em;height:2.2em;margin:0 1.875em;animation:swal2-rotate-loading 1.5s linear 0s infinite normal;border-width:.25em;border-style:solid;border-radius:100%;border-color:#2778c4 rgba(0,0,0,0) #2778c4 rgba(0,0,0,0)}div:where(.swal2-container) button:where(.swal2-styled){margin:.3125em;padding:.625em 1.1em;transition:var(--swal2-action-button-transition);border:none;box-shadow:0 0 0 3px rgba(0,0,0,0);font-weight:500}div:where(.swal2-container) button:where(.swal2-styled):not([disabled]){cursor:pointer}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-confirm){border-radius:var(--swal2-confirm-button-border-radius);background:initial;background-color:var(--swal2-confirm-button-background-color);box-shadow:var(--swal2-confirm-button-box-shadow);color:var(--swal2-confirm-button-color);font-size:1em}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-confirm):hover{background-color:color-mix(in srgb, var(--swal2-confirm-button-background-color), var(--swal2-action-button-hover))}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-confirm):active{background-color:color-mix(in srgb, var(--swal2-confirm-button-background-color), var(--swal2-action-button-active))}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-deny){border-radius:var(--swal2-deny-button-border-radius);background:initial;background-color:var(--swal2-deny-button-background-color);box-shadow:var(--swal2-deny-button-box-shadow);color:var(--swal2-deny-button-color);font-size:1em}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-deny):hover{background-color:color-mix(in srgb, var(--swal2-deny-button-background-color), var(--swal2-action-button-hover))}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-deny):active{background-color:color-mix(in srgb, var(--swal2-deny-button-background-color), var(--swal2-action-button-active))}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-cancel){border-radius:var(--swal2-cancel-button-border-radius);background:initial;background-color:var(--swal2-cancel-button-background-color);box-shadow:var(--swal2-cancel-button-box-shadow);color:var(--swal2-cancel-button-color);font-size:1em}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-cancel):hover{background-color:color-mix(in srgb, var(--swal2-cancel-button-background-color), var(--swal2-action-button-hover))}div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-cancel):active{background-color:color-mix(in srgb, var(--swal2-cancel-button-background-color), var(--swal2-action-button-active))}div:where(.swal2-container) button:where(.swal2-styled):focus-visible{outline:none;box-shadow:var(--swal2-action-button-focus-box-shadow)}div:where(.swal2-container) button:where(.swal2-styled)[disabled]:not(.swal2-loading){opacity:.4}div:where(.swal2-container) button:where(.swal2-styled)::-moz-focus-inner{border:0}div:where(.swal2-container) div:where(.swal2-footer){margin:1em 0 0;padding:1em 1em 0;border-top:1px solid var(--swal2-footer-border-color);background:var(--swal2-footer-background);color:var(--swal2-footer-color);font-size:1em;text-align:center;cursor:initial}div:where(.swal2-container) .swal2-timer-progress-bar-container{position:absolute;right:0;bottom:0;left:0;grid-column:auto !important;overflow:hidden;border-bottom-right-radius:var(--swal2-border-radius);border-bottom-left-radius:var(--swal2-border-radius)}div:where(.swal2-container) div:where(.swal2-timer-progress-bar){width:100%;height:.25em;background:var(--swal2-timer-progress-bar-background)}div:where(.swal2-container) img:where(.swal2-image){max-width:100%;margin:2em auto 1em;cursor:initial}div:where(.swal2-container) button:where(.swal2-close){position:var(--swal2-close-button-position);inset:var(--swal2-close-button-inset);z-index:2;align-items:center;justify-content:center;width:1.2em;height:1.2em;margin-top:0;margin-right:0;margin-bottom:-1.2em;padding:0;overflow:hidden;transition:var(--swal2-close-button-transition);border:none;border-radius:var(--swal2-border-radius);outline:var(--swal2-close-button-outline);background:rgba(0,0,0,0);color:var(--swal2-close-button-color);font-family:monospace;font-size:var(--swal2-close-button-font-size);cursor:pointer;justify-self:end}div:where(.swal2-container) button:where(.swal2-close):hover{transform:var(--swal2-close-button-hover-transform);background:rgba(0,0,0,0);color:#f27474}div:where(.swal2-container) button:where(.swal2-close):focus-visible{outline:none;box-shadow:var(--swal2-close-button-focus-box-shadow)}div:where(.swal2-container) button:where(.swal2-close)::-moz-focus-inner{border:0}div:where(.swal2-container) div:where(.swal2-html-container){z-index:1;justify-content:center;margin:0;padding:var(--swal2-html-container-padding);overflow:auto;color:inherit;font-size:1.125em;font-weight:normal;line-height:normal;text-align:center;overflow-wrap:break-word;word-break:break-word;cursor:initial}div:where(.swal2-container) input:where(.swal2-input),div:where(.swal2-container) input:where(.swal2-file),div:where(.swal2-container) textarea:where(.swal2-textarea),div:where(.swal2-container) select:where(.swal2-select),div:where(.swal2-container) div:where(.swal2-radio),div:where(.swal2-container) label:where(.swal2-checkbox){margin:1em 2em 3px}div:where(.swal2-container) input:where(.swal2-input),div:where(.swal2-container) input:where(.swal2-file),div:where(.swal2-container) textarea:where(.swal2-textarea){box-sizing:border-box;width:auto;transition:var(--swal2-input-transition);border:var(--swal2-input-border);border-radius:var(--swal2-input-border-radius);background:var(--swal2-input-background);box-shadow:var(--swal2-input-box-shadow);color:inherit;font-size:1.125em}div:where(.swal2-container) input:where(.swal2-input).swal2-inputerror,div:where(.swal2-container) input:where(.swal2-file).swal2-inputerror,div:where(.swal2-container) textarea:where(.swal2-textarea).swal2-inputerror{border-color:#f27474 !important;box-shadow:0 0 2px #f27474 !important}div:where(.swal2-container) input:where(.swal2-input):hover,div:where(.swal2-container) input:where(.swal2-file):hover,div:where(.swal2-container) textarea:where(.swal2-textarea):hover{box-shadow:var(--swal2-input-hover-box-shadow)}div:where(.swal2-container) input:where(.swal2-input):focus,div:where(.swal2-container) input:where(.swal2-file):focus,div:where(.swal2-container) textarea:where(.swal2-textarea):focus{border:var(--swal2-input-focus-border);outline:none;box-shadow:var(--swal2-input-focus-box-shadow)}div:where(.swal2-container) input:where(.swal2-input)::placeholder,div:where(.swal2-container) input:where(.swal2-file)::placeholder,div:where(.swal2-container) textarea:where(.swal2-textarea)::placeholder{color:#ccc}div:where(.swal2-container) .swal2-range{margin:1em 2em 3px;background:var(--swal2-background)}div:where(.swal2-container) .swal2-range input{width:80%}div:where(.swal2-container) .swal2-range output{width:20%;color:inherit;font-weight:600;text-align:center}div:where(.swal2-container) .swal2-range input,div:where(.swal2-container) .swal2-range output{height:2.625em;padding:0;font-size:1.125em;line-height:2.625em}div:where(.swal2-container) .swal2-input{height:2.625em;padding:0 .75em}div:where(.swal2-container) .swal2-file{width:75%;margin-right:auto;margin-left:auto;background:var(--swal2-input-background);font-size:1.125em}div:where(.swal2-container) .swal2-textarea{height:6.75em;padding:.75em}div:where(.swal2-container) .swal2-select{min-width:50%;max-width:100%;padding:.375em .625em;background:var(--swal2-input-background);color:inherit;font-size:1.125em}div:where(.swal2-container) .swal2-radio,div:where(.swal2-container) .swal2-checkbox{align-items:center;justify-content:center;background:var(--swal2-background);color:inherit}div:where(.swal2-container) .swal2-radio label,div:where(.swal2-container) .swal2-checkbox label{margin:0 .6em;font-size:1.125em}div:where(.swal2-container) .swal2-radio input,div:where(.swal2-container) .swal2-checkbox input{flex-shrink:0;margin:0 .4em}div:where(.swal2-container) label:where(.swal2-input-label){display:flex;justify-content:center;margin:1em auto 0}div:where(.swal2-container) div:where(.swal2-validation-message){align-items:center;justify-content:center;margin:1em 0 0;padding:.625em;overflow:hidden;background:var(--swal2-validation-message-background);color:var(--swal2-validation-message-color);font-size:1em;font-weight:300}div:where(.swal2-container) div:where(.swal2-validation-message)::before{content:\"!\";display:inline-block;width:1.5em;min-width:1.5em;height:1.5em;margin:0 .625em;border-radius:50%;background-color:#f27474;color:#fff;font-weight:600;line-height:1.5em;text-align:center}div:where(.swal2-container) .swal2-progress-steps{flex-wrap:wrap;align-items:center;max-width:100%;margin:1.25em auto;padding:0;background:rgba(0,0,0,0);font-weight:600}div:where(.swal2-container) .swal2-progress-steps li{display:inline-block;position:relative}div:where(.swal2-container) .swal2-progress-steps .swal2-progress-step{z-index:20;flex-shrink:0;width:2em;height:2em;border-radius:2em;background:#2778c4;color:#fff;line-height:2em;text-align:center}div:where(.swal2-container) .swal2-progress-steps .swal2-progress-step.swal2-active-progress-step{background:#2778c4}div:where(.swal2-container) .swal2-progress-steps .swal2-progress-step.swal2-active-progress-step~.swal2-progress-step{background:var(--swal2-progress-step-background);color:#fff}div:where(.swal2-container) .swal2-progress-steps .swal2-progress-step.swal2-active-progress-step~.swal2-progress-step-line{background:var(--swal2-progress-step-background)}div:where(.swal2-container) .swal2-progress-steps .swal2-progress-step-line{z-index:10;flex-shrink:0;width:2.5em;height:.4em;margin:0 -1px;background:#2778c4}div:where(.swal2-icon){position:relative;box-sizing:content-box;justify-content:center;width:5em;height:5em;margin:2.5em auto .6em;zoom:var(--swal2-icon-zoom);border:.25em solid rgba(0,0,0,0);border-radius:50%;border-color:#000;font-family:inherit;line-height:5em;cursor:default;user-select:none}div:where(.swal2-icon) .swal2-icon-content{display:flex;align-items:center;font-size:3.75em}div:where(.swal2-icon).swal2-error{border-color:#f27474;color:#f27474}div:where(.swal2-icon).swal2-error .swal2-x-mark{position:relative;flex-grow:1}div:where(.swal2-icon).swal2-error [class^=swal2-x-mark-line]{display:block;position:absolute;top:2.3125em;width:2.9375em;height:.3125em;border-radius:.125em;background-color:#f27474}div:where(.swal2-icon).swal2-error [class^=swal2-x-mark-line][class$=left]{left:1.0625em;transform:rotate(45deg)}div:where(.swal2-icon).swal2-error [class^=swal2-x-mark-line][class$=right]{right:1em;transform:rotate(-45deg)}@container swal2-popup style(--swal2-icon-animations:true){div:where(.swal2-icon).swal2-error.swal2-icon-show{animation:swal2-animate-error-icon .5s}div:where(.swal2-icon).swal2-error.swal2-icon-show .swal2-x-mark{animation:swal2-animate-error-x-mark .5s}}div:where(.swal2-icon).swal2-warning{border-color:#f8bb86;color:#f8bb86}@container swal2-popup style(--swal2-icon-animations:true){div:where(.swal2-icon).swal2-warning.swal2-icon-show{animation:swal2-animate-error-icon .5s}div:where(.swal2-icon).swal2-warning.swal2-icon-show .swal2-icon-content{animation:swal2-animate-i-mark .5s}}div:where(.swal2-icon).swal2-info{border-color:#3fc3ee;color:#3fc3ee}@container swal2-popup style(--swal2-icon-animations:true){div:where(.swal2-icon).swal2-info.swal2-icon-show{animation:swal2-animate-error-icon .5s}div:where(.swal2-icon).swal2-info.swal2-icon-show .swal2-icon-content{animation:swal2-animate-i-mark .8s}}div:where(.swal2-icon).swal2-question{border-color:#87adbd;color:#87adbd}@container swal2-popup style(--swal2-icon-animations:true){div:where(.swal2-icon).swal2-question.swal2-icon-show{animation:swal2-animate-error-icon .5s}div:where(.swal2-icon).swal2-question.swal2-icon-show .swal2-icon-content{animation:swal2-animate-question-mark .8s}}div:where(.swal2-icon).swal2-success{border-color:#a5dc86;color:#a5dc86}div:where(.swal2-icon).swal2-success [class^=swal2-success-circular-line]{position:absolute;width:3.75em;height:7.5em;border-radius:50%}div:where(.swal2-icon).swal2-success [class^=swal2-success-circular-line][class$=left]{top:-0.4375em;left:-2.0635em;transform:rotate(-45deg);transform-origin:3.75em 3.75em;border-radius:7.5em 0 0 7.5em}div:where(.swal2-icon).swal2-success [class^=swal2-success-circular-line][class$=right]{top:-0.6875em;left:1.875em;transform:rotate(-45deg);transform-origin:0 3.75em;border-radius:0 7.5em 7.5em 0}div:where(.swal2-icon).swal2-success .swal2-success-ring{position:absolute;z-index:2;top:-0.25em;left:-0.25em;box-sizing:content-box;width:100%;height:100%;border:.25em solid rgba(165,220,134,.3);border-radius:50%}div:where(.swal2-icon).swal2-success .swal2-success-fix{position:absolute;z-index:1;top:.5em;left:1.625em;width:.4375em;height:5.625em;transform:rotate(-45deg)}div:where(.swal2-icon).swal2-success [class^=swal2-success-line]{display:block;position:absolute;z-index:2;height:.3125em;border-radius:.125em;background-color:#a5dc86}div:where(.swal2-icon).swal2-success [class^=swal2-success-line][class$=tip]{top:2.875em;left:.8125em;width:1.5625em;transform:rotate(45deg)}div:where(.swal2-icon).swal2-success [class^=swal2-success-line][class$=long]{top:2.375em;right:.5em;width:2.9375em;transform:rotate(-45deg)}@container swal2-popup style(--swal2-icon-animations:true){div:where(.swal2-icon).swal2-success.swal2-icon-show .swal2-success-line-tip{animation:swal2-animate-success-line-tip .75s}div:where(.swal2-icon).swal2-success.swal2-icon-show .swal2-success-line-long{animation:swal2-animate-success-line-long .75s}div:where(.swal2-icon).swal2-success.swal2-icon-show .swal2-success-circular-line-right{animation:swal2-rotate-success-circular-line 4.25s ease-in}}[class^=swal2]{-webkit-tap-highlight-color:rgba(0,0,0,0)}.swal2-show{animation:var(--swal2-show-animation)}.swal2-hide{animation:var(--swal2-hide-animation)}.swal2-noanimation{transition:none}.swal2-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}.swal2-rtl .swal2-close{margin-right:initial;margin-left:0}.swal2-rtl .swal2-timer-progress-bar{right:0;left:auto}.swal2-toast{box-sizing:border-box;grid-column:1/4 !important;grid-row:1/4 !important;grid-template-columns:min-content auto min-content;padding:1em;overflow-y:hidden;border:var(--swal2-toast-border);background:var(--swal2-background);box-shadow:var(--swal2-toast-box-shadow);pointer-events:all}.swal2-toast>*{grid-column:2}.swal2-toast h2:where(.swal2-title){margin:.5em 1em;padding:0;font-size:1em;text-align:initial}.swal2-toast .swal2-loading{justify-content:center}.swal2-toast input:where(.swal2-input){height:2em;margin:.5em;font-size:1em}.swal2-toast .swal2-validation-message{font-size:1em}.swal2-toast div:where(.swal2-footer){margin:.5em 0 0;padding:.5em 0 0;font-size:.8em}.swal2-toast button:where(.swal2-close){grid-column:3/3;grid-row:1/99;align-self:center;width:.8em;height:.8em;margin:0;font-size:2em}.swal2-toast div:where(.swal2-html-container){margin:.5em 1em;padding:0;overflow:initial;font-size:1em;text-align:initial}.swal2-toast div:where(.swal2-html-container):empty{padding:0}.swal2-toast .swal2-loader{grid-column:1;grid-row:1/99;align-self:center;width:2em;height:2em;margin:.25em}.swal2-toast .swal2-icon{grid-column:1;grid-row:1/99;align-self:center;width:2em;min-width:2em;height:2em;margin:0 .5em 0 0}.swal2-toast .swal2-icon .swal2-icon-content{display:flex;align-items:center;font-size:1.8em;font-weight:bold}.swal2-toast .swal2-icon.swal2-success .swal2-success-ring{width:2em;height:2em}.swal2-toast .swal2-icon.swal2-error [class^=swal2-x-mark-line]{top:.875em;width:1.375em}.swal2-toast .swal2-icon.swal2-error [class^=swal2-x-mark-line][class$=left]{left:.3125em}.swal2-toast .swal2-icon.swal2-error [class^=swal2-x-mark-line][class$=right]{right:.3125em}.swal2-toast div:where(.swal2-actions){justify-content:flex-start;height:auto;margin:0;margin-top:.5em;padding:0 .5em}.swal2-toast button:where(.swal2-styled){margin:.25em .5em;padding:.4em .6em;font-size:1em}.swal2-toast .swal2-success{border-color:#a5dc86}.swal2-toast .swal2-success [class^=swal2-success-circular-line]{position:absolute;width:1.6em;height:3em;border-radius:50%}.swal2-toast .swal2-success [class^=swal2-success-circular-line][class$=left]{top:-0.8em;left:-0.5em;transform:rotate(-45deg);transform-origin:2em 2em;border-radius:4em 0 0 4em}.swal2-toast .swal2-success [class^=swal2-success-circular-line][class$=right]{top:-0.25em;left:.9375em;transform-origin:0 1.5em;border-radius:0 4em 4em 0}.swal2-toast .swal2-success .swal2-success-ring{width:2em;height:2em}.swal2-toast .swal2-success .swal2-success-fix{top:0;left:.4375em;width:.4375em;height:2.6875em}.swal2-toast .swal2-success [class^=swal2-success-line]{height:.3125em}.swal2-toast .swal2-success [class^=swal2-success-line][class$=tip]{top:1.125em;left:.1875em;width:.75em}.swal2-toast .swal2-success [class^=swal2-success-line][class$=long]{top:.9375em;right:.1875em;width:1.375em}@container swal2-popup style(--swal2-icon-animations:true){.swal2-toast .swal2-success.swal2-icon-show .swal2-success-line-tip{animation:swal2-toast-animate-success-line-tip .75s}.swal2-toast .swal2-success.swal2-icon-show .swal2-success-line-long{animation:swal2-toast-animate-success-line-long .75s}}.swal2-toast.swal2-show{animation:var(--swal2-toast-show-animation)}.swal2-toast.swal2-hide{animation:var(--swal2-toast-hide-animation)}@keyframes swal2-show{0%{transform:translate3d(0, -50px, 0) scale(0.9);opacity:0}100%{transform:translate3d(0, 0, 0) scale(1);opacity:1}}@keyframes swal2-hide{0%{transform:translate3d(0, 0, 0) scale(1);opacity:1}100%{transform:translate3d(0, -50px, 0) scale(0.9);opacity:0}}@keyframes swal2-animate-success-line-tip{0%{top:1.1875em;left:.0625em;width:0}54%{top:1.0625em;left:.125em;width:0}70%{top:2.1875em;left:-0.375em;width:3.125em}84%{top:3em;left:1.3125em;width:1.0625em}100%{top:2.8125em;left:.8125em;width:1.5625em}}@keyframes swal2-animate-success-line-long{0%{top:3.375em;right:2.875em;width:0}65%{top:3.375em;right:2.875em;width:0}84%{top:2.1875em;right:0;width:3.4375em}100%{top:2.375em;right:.5em;width:2.9375em}}@keyframes swal2-rotate-success-circular-line{0%{transform:rotate(-45deg)}5%{transform:rotate(-45deg)}12%{transform:rotate(-405deg)}100%{transform:rotate(-405deg)}}@keyframes swal2-animate-error-x-mark{0%{margin-top:1.625em;transform:scale(0.4);opacity:0}50%{margin-top:1.625em;transform:scale(0.4);opacity:0}80%{margin-top:-0.375em;transform:scale(1.15)}100%{margin-top:0;transform:scale(1);opacity:1}}@keyframes swal2-animate-error-icon{0%{transform:rotateX(100deg);opacity:0}100%{transform:rotateX(0deg);opacity:1}}@keyframes swal2-rotate-loading{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes swal2-animate-question-mark{0%{transform:rotateY(-360deg)}100%{transform:rotateY(0)}}@keyframes swal2-animate-i-mark{0%{transform:rotateZ(45deg);opacity:0}25%{transform:rotateZ(-25deg);opacity:.4}50%{transform:rotateZ(15deg);opacity:.8}75%{transform:rotateZ(-5deg);opacity:1}100%{transform:rotateX(0);opacity:1}}@keyframes swal2-toast-show{0%{transform:translateY(-0.625em) rotateZ(2deg)}33%{transform:translateY(0) rotateZ(-2deg)}66%{transform:translateY(0.3125em) rotateZ(2deg)}100%{transform:translateY(0) rotateZ(0deg)}}@keyframes swal2-toast-hide{100%{transform:rotateZ(1deg);opacity:0}}@keyframes swal2-toast-animate-success-line-tip{0%{top:.5625em;left:.0625em;width:0}54%{top:.125em;left:.125em;width:0}70%{top:.625em;left:-0.25em;width:1.625em}84%{top:1.0625em;left:.75em;width:.5em}100%{top:1.125em;left:.1875em;width:.75em}}@keyframes swal2-toast-animate-success-line-long{0%{top:1.625em;right:1.375em;width:0}65%{top:1.25em;right:.9375em;width:0}84%{top:.9375em;right:0;width:1.125em}100%{top:.9375em;right:.1875em;width:1.375em}}");
/**
* @license AGPL-3.0
* Blooket Cheats
* Copyright (C) 2023-present 05Konz/Xullys/redhorse26/landsedge/Tony-the-best
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Source: TAKEN DOWN! * EMAIL: [email protected]
* Source: https://github.com/xgui-client/X-GUI-BLOOKET-CLIENT/ * EMAIL [email protected]
*/
/* THE UPDATE CHECKER IS ADDED DURING COMMIT PREP, THERE MAY BE REDUNDANT CODE, DO NOT TOUCH */
console.log("%c X-GUI CLIENT LOADED! ENJOY! %c\n Created by Xullys on GitHub", "color: #0bc2cf; font-size: 3rem", "color: #8000ff; font-size: 1rem");
console.log("%c gui.js", "color: #0bc2cf; font-size: 1rem");
console.log("%c Star the GitHub repo! %c https://github.com/xgui-client/X-GUI-BLOOKET-CLIENT", "color: #ffd000; font-size: 1rem", "color: #8000ff; font-size: 1rem");
(() => {
let iframe = document.querySelector("iframe");
if (!iframe) {
iframe = document.createElement("iframe");
iframe.style.display = "none";
document.body.append(iframe);
}
/* By CryptoDude3 */
if (window.fetch.call.toString() == 'function call() { [native code] }') {
const call = window.fetch.call;
window.fetch.call = function() {
if (!arguments[1].includes("s.blooket.com/rc")) return call.apply(this, arguments);
}
}
const timeProcessed = 1747005941679;
let latestProcess = -1;
const cheat = (async () => {
const versionName = "6.70x";
const gui = document.createElement("div");
Object.assign(gui.style, {
top: window.innerHeight / 2 - 250 + "px",
left: innerWidth / 2 - 400 + "px",
});
const variables = {
"--highlight": "#8A2BE2",
"--highlight2": "#4B0082",
"--background": "#0B0B1E",
"--background2": "#151534",
"--textColor": "#E0E0FF",
"--textColor2": "#9A8CFF",
"--toggleOff": "#2C273F",
"--toggleOn": "#5FA3FF",
};
let settings,
settingsKey = "KGUI.BenIsASillyGoose";
const Settings = {
data: null,
setItem(k, v) {
k.split(".").reduce((obj, k, i, a) => (++i == a.length && (obj[k] = v), k in obj ? obj[k] : (obj[k] = {})), this.data);
localStorage.setItem(settingsKey, JSON.stringify(this.data));
return v;
},
deleteItem(k) {
k.split(".").reduce((obj, k, i, a) => (++i == a.length && delete obj[k], obj[k]), this.data);
localStorage.setItem(settingsKey, JSON.stringify(this.data));
return this.data;
},
setData(v) {
this.data = v;
localStorage.setItem(settingsKey, JSON.stringify(this.data));
},
};
const defaultHideKey = {
ctrl: true,
shift: false,
alt: false,
key: "e"
};
const defaultCloseKey = {
ctrl: true,
shift: false,
alt: false,
key: "x"
};
for (const variable in variables) gui.style.setProperty(variable, variables[variable]);
try {
Settings.data = JSON.parse(localStorage.getItem(settingsKey) || "{}");
} catch {
localStorage.setItem(settingsKey, "{}");
Settings.data = {};
} finally {
for (const variable in Settings.data.theme || {}) gui.style.setProperty("--" + variable, Settings.data.theme[variable]);
Settings.data.hideKey ??= defaultHideKey;
Settings.data.closeKey ??= defaultCloseKey;
}
const CookieHelper = {
setCookie: (name, value, days = 365) => {
const date = new Date();
date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
const expires = "expires=" + date.toUTCString();
document.cookie = `${name}=${encodeURIComponent(JSON.stringify(value))}; domain=.blooket.com; ${expires};path=/`;
},
getCookie: (name) => {
const nameEQ = name + "=";
const cookies = document.cookie.split(';');
for (let cookie of cookies) {
cookie = cookie.trim();
if (cookie.indexOf(nameEQ) === 0) {
try {
return JSON.parse(decodeURIComponent(cookie.substring(nameEQ.length)));
} catch {
return null;
}
}
}
return null;
}
};
const styles = document.createElement("style");
const classes = {},
datasets = {};
styles.innerHTML =
"@import url('https://fonts.googleapis.com/css?family=Titan+One');\n@import url('https://fonts.googleapis.com/css?family=Nunito');" +
`.bigTextContainer,.version{align-items:center;user-select:none}.cheatsList>div,.settingsPage>div{padding:5px 10px}.gamemode,.gui,.leaderboardList,.sidebar{box-sizing:border-box}.controls>div,.credit,.pathText,.runCheat,.sidebarPath,.version{user-select:none}.noScroll::-webkit-scrollbar{display:none}.noScroll{-ms-overflow-style:none;scrollbar-width:none}.gui {
position: fixed;
z-index: 100;
background: var(--background);
height: 500px;
width: 800px;
color: #fff;
padding-left: 50px;
font-size: 16px;
/* clean corners */
border-radius: 20px;
overflow: hidden; /* hides overlapping sidebar edges */
/* strobing purple edge */
box-shadow: 0 0 15px var(--highlight);
animation: edgePulse 2s ease-in-out infinite;
}
/* add a wrapper to keep glow around full rounded border */
.gui::after {
content: "";
position: absolute;
inset: 0;
border-radius: 20px;
border: 2px solid var(--highlight);
pointer-events: none; /* lets you click through it */
animation: edgePulse 2s ease-in-out infinite;
}
/* animate border glow */
@keyframes edgePulse {
0% {
border-color: var(--highlight);
box-shadow: 0 0 10px var(--highlight);
}
50% {
border-color: var(--highlight2);
box-shadow: 0 0 25px var(--highlight2);
}
100% {
border-color: var(--highlight);
box-shadow: 0 0 10px var(--highlight);
}
}
button,
.runCheat,
.cheatToggle,
.toggleTrigger,
.controls > div,
.searchbarButton {
border-radius: 12px !important;
}
.controls,.credit,.gamemodesList,.guiContent,.guiTopBar,.sidebar,.sidebarShadow,.version{position:absolute}.sidebarShadow{inset:0;background:#000;opacity:0%;pointer-events:none;transition:.2s;z-index:9}.controls>div,.guiContent,.sidebar,select[data-type] option{background:var(--background2)}.sidebarShadow:has(~ .sidebar:hover){opacity:40%}.credit{bottom:0;left:0;right:0;height:0;transition:.1s;overflow:hidden;text-align:center}.sidebar {
top: 0;
left: 0;
height: 100%;
width: 50px;
/* ORIGINAL POSITIONING */
position: absolute;
z-index: 10;
/* visuals */
background: var(--background2);
box-sizing: border-box;
padding-bottom: 30px;
/* animation */
transition: width .2s .1s;
/* COLLAPSED */
overflow-x: hidden;
overflow-y: hidden;
}
/* EXPANDED */
.sidebar:hover {
width: 200px;
overflow-y: auto;
}
/* Chrome scrollbar */
.sidebar::-webkit-scrollbar {
width: 0;
}
.sidebar:hover::-webkit-scrollbar {
width: 6px;
}
.sidebar:hover::-webkit-scrollbar-thumb {
background: rgba(255, 255, 255, 0.25);
border-radius: 6px;
}
.sidebar:hover{width:200px;transition-delay:0s}.sidebar:hover>.credit{height:25px;transition:.4s 0.2s}.guiContent{inset:20px;left:70px;top:40px;z-index:1;padding-top:32px}.guiTopBar{z-index:1;top:0;left:50px;right:0;height:25px}.version{top:0;left:0;margin-inline:10px;color:#888;font-size:.9em;letter-spacing:.5px;height:100%;display:flex}.controls{top:0;right:0;display:grid;grid-template-columns:1fr 1fr 1fr;height:25px;width:122px;gap:1px;border:1px solid var(--background);z-index:2}.controls>div{display:grid;place-items:center;font-weight:100}.closeControl{transition:.1s}.closeControl:hover{background:red}.creditsPage,.gamemodesPage,.searchPage{position:absolute;inset:0;top:32px}.gamemodesList{display:grid;gap:0 30px;padding-inline:30px;margin-top:0;padding-top:15px;margin-bottom:0;grid-template-columns:1fr 1fr;overflow-y:scroll;inset:0}.leaderboardPage,.logsPage{inset:10px;position:absolute}.pathText{position:absolute;top:40px;left:70px;right:20px;z-index:3;padding:7px 10px;height:22px}.clearLogsButton,.refreshControl{z-index:5;place-items:center;cursor:pointer}.leaderboardPage{top:42px}.leaderboardList{list-style:none;margin:0;padding:20px 40px 10px;height:100%;overflow:scroll;font-size:1.5em}.logsPage{top:37px;background:#000d;border-radius:2.5px}.logMessages{list-style:none;margin:10px;padding:0;display:flex;flex-direction:column-reverse;overflow-y:scroll;word-wrap:break-word;position:absolute;inset:0}.clearLogsButton{position:absolute;top:5px;right:5px;width:25px;height:25px;display:grid;scale:-1 1 1;transition:.2s}.searchbarHolder{display:flex;outline:2px solid var(--highlight);margin:10px 20px;height:30px;font-size:2em}.searchbarInput{outline:0;border:none;background:0 0;color:#fff;flex:1;font-size:.5em;font-family:Nunito;padding-inline:5px}.gamemode,.settingsPage>div{border-radius:2.5px;background:var(--background)}.searchbarButton{color:#fff;font-size:.6em;aspect-ratio:1/1;height:30px;display:grid;place-items:center;cursor:pointer}.bigText,.bigTextContainer{height:50px;width:200px;font-family:Titan One}.searchResults{position:absolute;inset:0;top:45px;padding-inline:20px;overflow-y:scroll}.favoritesPage,.settingsPage{inset:0;top:32px;overflow-y:scroll;position:absolute}.noResult{margin:20px 10px;font-size:.85em}.clearLogsButton:hover,.licenseMessage{font-size:1.25em}.favoritesPage{padding-block:10px;padding-inline:20px}.licenseMessage{font-weight:900;padding-inline:20px;margin-top:10px}.copyrightTag{font-size:.7em;font-weight:200;position:absolute;bottom:0;left:0;padding:5px 8px}.codingCredits,.creditLinks,.uploadDates{list-style:none;padding-inline:20px;margin-block:16px}.settingsPage{padding:10px;display:flex;flex-direction:column;gap:10px}.sidebarPaths{display:flex;flex-direction:column;width:200px}.bigTextContainer{display:flex;font-size:2em;margin-block:10px;transition:font-size .2s .1s,margin-block .2s .1s}.bigText{display:flex;align-items:center;justify-content:center}.refreshControl{position:absolute;top:45px;right:25px;width:25px;height:25px;display:grid}.gamemode{width:100%;height:200px;margin-bottom:30px;cursor:pointer;display:flex;justify-content:center;align-items:center;padding-top:10px;position:relative;overflow:hidden;padding-bottom:35px;transition:.4s}.contentPage,.gamemode>div{position:absolute;bottom:0}.gamemode:hover{box-shadow:0 0 10px var(--highlight);transition:.2s}.gamemode>img{width:85%;max-width:100%;max-height:100%}.gamemode>div{left:0;right:0;height:25px;background:var(--highlight);display:flex;justify-content:center;align-items:center;box-shadow:0 -5px 5px #0004;font-weight:800;font-size:1.1em;transition:.25s}.contentPage{inset-inline:0;top:35px}.cheatsList{display:flex;flex-direction:column;height:100%;overflow-y:scroll;padding-inline:10px}.cheatToggle,.cheatToggle>.toggleTrigger,.runCheat{height:35px;border-radius:2.5px}.cheatsList>div{display:grid;margin-bottom:10px;position:relative;background:var(--background);border-radius:2.5px}.cheatInfo,.cheatInputs,.cheatName,.cheatTop,.logMessage>span,.runCheat,.sidebarPath,.sidebarPath>i{display:flex}.cheatInfo{flex-direction:column;flex:1}.cheatName{font-size:1.5em;font-weight:700}.cheatDescription{font-size:.8em;margin-right:25px}.runCheat{--buttonColor:var(--highlight);width:20%;background:var(--buttonColor);margin-block:auto;cursor:pointer;align-items:center;justify-content:center;font-weight:800;transition:.5s;color:#fff!important}.runCheat:hover{box-shadow:0 0 10px 0 var(--buttonColor);transition:.3s}.runCheat:active{box-shadow:0 0 0 0 var(--buttonColor);transition:50ms}.cheatInputs{margin:5px 0 5px 5px;flex-direction:column;gap:5px}.searchResult,.standing{margin-bottom:10px;transition:.2s}.creditsPage>ul>li>strong,.logMessage img,.standingBlook{margin-right:5px}.cheatInputs>div{display:flex;flex-direction:row;font-size:.8rem;color:var(--highlight);font-weight:700;align-items:center}.cheatInputs>div>span{flex:1}.cheatToggle{width:20%;background:var(--highlight2);margin-block:auto;cursor:pointer;position:relative}.cheatToggle>.toggleTrigger{width:45px;position:absolute;top:0;left:0;background:var(--highlight);pointer-events:none;transition:left .2s,box-shadow .5s;z-index:1}.cheatToggle:hover>.toggleTrigger{box-shadow:0 0 10px 0 var(--highlight);transition:left .2s,box-shadow .2s}.toggleTrigger.active{left:calc(100% - 45px)}.toggleColor{position:absolute;inset:10px 20px;background:rgb(from var(--toggleOff) r g b / 25%);border-radius:2.5px;transition:.2s}.toggleTrigger.active+.toggleColor{background:rgb(from var(--toggleOn) r g b / 25%)}input[data-type],select[data-type]{width:20%;height:25px;outline:0;border:2px solid var(--highlight);box-sizing:border-box;background:0 0;color:#fff;font-size:.9em;padding-left:5px;font-family:Nunito;border-radius:2px;font-weight:800}.logo,.sidebarPath>i{width:50px;height:50px}select[data-type]{-webkit-appearance:none;-moz-appearance:none;text-indent:1px;text-overflow:''}input::placeholder{color:rgb(from var(--textColor) r g b / 50%)}input[data-type]::-webkit-inner-spin-button,input[data-type]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[data-type][type=number]{-moz-appearance:textfield}select[data-type] option{border-radius:0}select[data-type]::-ms-expand{display:none}.sidebarPath{align-items:center;cursor:pointer;transition:.2s 0.1s}.searchResult:hover,.sidebarPath:hover{color:var(--highlight);text-shadow:0 0 5px var(--highlight)}.sidebarPath>i{justify-content:center;align-items:center;font-size:1.5em}.sidebarPath>span{padding-left:5px}.sidebar:hover .sidebarPath{padding-left:20px;transition-delay:0s}.logo{left:0;transition:left .2s .1s;display:grid;place-items:center;min-width:50px;position:absolute}.sidebar:hover .logo{left:28px;transition:left .2s}.bigText{margin-top:-150px;transition:margin-top .1s}.sidebar:hover .bigText{margin-top:0;transition:margin-top .4s 0.1s}.sidebar:hover .bigTextContainer{font-size:2.5em;margin-block:20px;transition:font-size .2s,margin-block .2s}/* === Glowing title effect === */
.bigText {
text-shadow: 0 0 10px var(--highlight), 0 0 20px var(--highlight2);
animation: glowPulse 2s ease-in-out infinite alternate;
}
@keyframes glowPulse {
from { text-shadow: 0 0 10px var(--highlight); }
to { text-shadow: 0 0 25px var(--highlight2), 0 0 40px var(--highlight); }
}
/* === Search animation effects === */
@keyframes slideInLeft {
from {
opacity: 0;
transform: translateX(-30px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
@keyframes slideOutRight {
from {
opacity: 1;
transform: translateX(0);
}
to {
opacity: 0;
transform: translateX(30px);
}
}
@keyframes fadeIn {
from { opacity: 0; }
to { opacity: 1; }
}
@keyframes fadeOut {
from { opacity: 1; }
to { opacity: 0; }
}
/* === GUI fade animations === */
@keyframes guiFadeIn {
from {
opacity: 0;
transform: scale(0.95);
}
to {
opacity: 1;
transform: scale(1);
}
}
@keyframes guiFadeOut {
from {
opacity: 1;
transform: scale(1);
}
to {
opacity: 0;
transform: scale(0.95);
}
}
/* === Page transition animations === */
@keyframes pageIn {
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.gui {
animation: guiFadeIn 0.3s ease-out;
}
.gui.hiding {
animation: guiFadeOut 0.3s ease-out;
}
.creditsPage>ul>li>span{color:var(--textColor2);font-weight:800}.creditsPage>ul>li i{margin-inline:2px;line-height:1}.creditsPage a{color:var(--highlight);text-decoration:none}.creditsPage a:hover,.pathPage:hover{text-decoration:underline}.warning{color:var(--highlight2);font-size:.85em}.searchResult{cursor:pointer}.searchResultName{font-weight:800}.searchResultDescription{font-size:.8em}.searchResultSeparator{font-size:1.5em;font-weight:800;margin-block:10px;cursor:pointer;transition:.2s;border-bottom:2px solid #fff;padding-inline:5px;filter:drop-shadow(0px 0px 0px var(--highlight))}.searchResultSeparator:hover{color:var(--highlight);border-bottom:2px solid var(--highlight);filter:drop-shadow(0px 0px 2.5px var(--highlight))}.toggleCheat{--buttonColor:var(--toggleOff)}.toggleCheat.active{--buttonColor:var(--toggleOn)}.logMessage img{height:1em;align-self:center}.standing{display:flex;font-weight:800;align-items:center;position:relative;padding:5px 10px 5px 50px;border-radius:2.5px;background:var(--highlight2)}.standing:before{content:attr(data-place) ".";margin-right:10px}.standing::after{content:attr(data-value);flex:1;text-align:right;font-weight:100}.standing:hover{background:var(--standingColor);box-shadow:0 0 7.5px var(--standingColor)}.standingBlook{height:1.25em;align-self:center;position:absolute;left:10px}.favoriteButton,.favoriteButton>i{transition:.2s;display:grid;place-items:center;width:32px;height:32px}.favoriteButton{font-size:.8em;padding-left:5px;cursor:pointer}.favoriteButton:hover{color:#ff0}.favoriteButton>i{position:absolute;scale:0;transform-origin:50% 55%}.favoriteButton>i.filled{scale:1}.pathPage{cursor:pointer;color:var(--highlight)}[data-favorited=false],[data-favorites="0"]{display:none}
[data-mode][data-name][data-description] {}`
.replace(/\.([^0-9][\w-]+)/gm, (x, y) => "." + (classes[y] ??= randString(10)))
.replace(/data-(\w+)/gm, (x, y) => "data-" + (datasets[y] ??= randString(10)));
gui.className = classes.gui;
gui.append(styles);
function roundGamemodeBoxes() {
// Select only the gamemode tiles via the obfuscated class name
const gamemodes = gui.querySelectorAll("." + classes.gamemode);
gamemodes.forEach(tile => {
tile.style.borderRadius = "15px"; // clean rounded edges
tile.style.overflow = "hidden"; // keeps images clipped cleanly
});
}
// delay ensures elements exist
setTimeout(roundGamemodeBoxes, 50);
const sidebarShadow = document.createElement("div");
sidebarShadow.className = classes.sidebarShadow;
gui.appendChild(sidebarShadow);
const credit = document.createElement("div");
credit.className = classes.credit;
const sidebar = document.createElement("div");
sidebar.className = classes.sidebar;
sidebar.append(credit);
const guiContent = document.createElement("div");
guiContent.className = classes.guiContent;
const guiTopBar = document.createElement("div");
guiTopBar.className = classes.guiTopBar;
guiTopBar.style.cursor = "grab"; // Make it clear the top bar is draggable
dragElement(guiTopBar, gui); // Allow dragging from the entire top bar
const version = document.createElement("span");
version.className = classes.version;
version.innerText = "Tony-the-best - X-GUI " + versionName;
guiTopBar.append(version);
const style = document.createElement("style");
style.textContent = `
.xgui-i {
width: 16px;
height: 16px;
display: inline-block;
background-repeat: no-repeat;
background-position: center;
background-size: 16px 16px;
pointer-events: none;
}
/* MOVE <--> */
.xgui-move {
background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'>\
<path d='M4 12l4-4v3h8V8l4 4-4 4v-3H8v3z'/>\
</svg>");
}
/* MINUS */
.xgui-min {
background-image: url(\"data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'>\
<rect x='4' y='11' width='16' height='2'/>\
</svg>\");
}
/* FULLSCREEN */
.xgui-full {
background-image: url(\"data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'>\
<path d='M4 4h6v2H6v4H4V4zm10 0h6v6h-2V6h-4V4zm6 10v6h-6v-2h4v-4h2zm-16 6h6v-2H6v-4H4v6z'/>\
</svg>\");
}
/* CLOSE X */
.xgui-close {
background-image: url(\"data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' stroke='white' stroke-width='2' fill='none'>\
<line x1='4' y1='4' x2='20' y2='20'/>\
<line x1='20' y1='4' x2='4' y2='20'/>\
</svg>\");
}
`;
document.head.appendChild(style);
const controls = document.createElement("div");
controls.className = classes.controls;
// MOVE
const moveControl = document.createElement("div");
moveControl.style.cursor = "grab";
moveControl.innerHTML = `<i class="xgui-i xgui-move"></i>`;
dragElement(moveControl, gui);
// MINIMIZE
const minimizeControl = document.createElement("div");
minimizeControl.minimized = false;
let hideAnimation = false;
function setMinIcon(min) {
minimizeControl.innerHTML =
`<i class="xgui-i ${min ? "xgui-min" : "xgui-full"}"></i>`;
}
setMinIcon(true);
minimizeControl.onclick = () => {
if (hideAnimation) return;
hideAnimation = true;
const hidden = minimizeControl.minimized;
setMinIcon(hidden);
gui.animate(
[{
width: hidden ? "122px" : "800px",
height: hidden ? "27px" : "500px",
left: gui.style.left
},
{
width: hidden ? "800px" : "122px",
height: hidden ? "500px" : "27px",
left: `${parseInt(gui.style.left) + (hidden ? -678 : 678)}px`
}
], {
duration: 200,
easing: "ease"
}
);
gui.style.width = hidden ? "800px" : "122px";
gui.style.height = hidden ? "500px" : "27px";
setTimeout(() => {
for (const child of gui.children) {
if (child === controls) continue;
if (hidden) child.style.display = child._display;
else {
child._display = child.style.display;
child.style.display = "none";
}
}
hideAnimation = false;
}, hidden ? 200 : 0);
gui.style.left = `${parseInt(gui.style.left) + (hidden ? -678 : 678)}px`;
minimizeControl.minimized = !hidden;
};
// CLOSE
const closeControl = document.createElement("div");
closeControl.innerHTML = `<i class="xgui-i xgui-close"></i>`;
closeControl.onclick = () => {
// Check if animations are enabled
const animationsEnabled = getCookieValue("animationsEnabled");
if (animationsEnabled) {
// Add fade out animation before closing
const animationDuration = 0.3; // 300ms
gui.style.animation = `guiFadeOut ${animationDuration}s ease-out forwards`;
gui.style.pointerEvents = 'none'; // Prevent interaction during animation
setTimeout(() => {
gui.remove();
}, animationDuration * 1000);
} else {
// No animation, immediately close
gui.remove();
}
};
// APPEND
controls.append(moveControl, minimizeControl, closeControl);
gui.appendChild(controls);
// ======= PERSISTENCE =======
const PERSIST_KEY = "xgui_state_v4";
const SHIFT = 678; // minimize offset
function saveGUIState() {
try {
if (gui.dataset.mobileMode === "true") return; // skip in mobile mode
const rect = gui.getBoundingClientRect();
const isMin = minimizeControl.minimized;
let left = parseInt(gui.style.left) || rect.left;
let top = parseInt(gui.style.top) || rect.top;
if (isMin) left -= SHIFT;
const state = {
left,
top,
minimized: isMin
};
document.cookie = PERSIST_KEY + "=" + encodeURIComponent(JSON.stringify(state)) + "; path=/; domain=.blooket.com; expires=Tue, 19 Jan 2038 03:14:07 GMT";
} catch {}
}
function loadGUIState() {
try {
if (gui.dataset.mobileMode === "true") return {}; // skip in mobile mode
const m = document.cookie.match(new RegExp(PERSIST_KEY + "=([^;]+)"));
return m ? JSON.parse(decodeURIComponent(m[1])) : {};
} catch {
return {};
}
}
// Restore position and minimized state
(async function restoreGUI() {
while (!gui || !minimizeControl || !moveControl || gui.children.length < 2) {
await new Promise(r => setTimeout(r, 25));
}
if (gui.dataset.mobileMode === "true") return; // skip in mobile mode
const s = loadGUIState();
if (s.left || s.top) {
gui.style.width = "800px";
gui.style.height = "500px";
gui.style.left = s.left + "px";
gui.style.top = s.top + "px";
await new Promise(r => setTimeout(r, 20));
if (s.minimized) minimizeControl.onclick(); // trigger minimize animation
}
})();
// Save after drag
document.addEventListener("pointerup", () => {
if (gui.dataset.mobileMode === "true") return;
setTimeout(saveGUIState, 30);
});
// Save before unload
window.addEventListener("beforeunload", () => {
if (gui.dataset.mobileMode === "true") return;
saveGUIState();
});
const gamemodesPage = document.createElement("div");
gamemodesPage.className = classes.gamemodesPage;
const gamemodesList = document.createElement("div");
gamemodesList.className = classes.noScroll + " " + classes.gamemodesList;
const path = [
["Gamemodes", gamemodesPage]
];
// Global animation settings
window.xguiAnimationsEnabled = true; // Default to true
const getCookieValue = (name) => {
const cookieValue = getCookie(name);
return cookieValue === null ? true : cookieValue === "true";
};
// Check if animations are enabled from cookie
setTimeout(() => {
window.xguiAnimationsEnabled = getCookieValue("animationsEnabled");
}, 10);
const pathText = document.createElement("div");
pathText.className = classes.pathText;
path.createPage = function(name, index, current) {
const page = document.createElement("span");
page.innerText = name;
if (!current) page.className = classes.pathPage;
page.onclick = () => this.goto(index);
return page;
};
path.updatePath = function() {
pathText.innerHTML = "";
pathText.append(this.createPage(this[0][0], 0, this.length == 1));
for (let i = 1; i < this.length; i++) {
pathText.append(" > ");
pathText.append(this.createPage(this[i][0], i, this.length - 1 == i));
}
guiContent.innerHTML = "";
const newPage = this[this.length - 1][1];
guiContent.append(newPage);
// Add page transition animation if enabled
if (window.xguiAnimationsEnabled && newPage) {
newPage.style.animation = "pageIn 0.3s ease-out";
} else if (newPage) {
// Clear animation if disabled
newPage.style.animation = "none";
}
this[this.length - 1][1]?.onPath?.();
};
path.push = function(key, page) {
Array.prototype.push.call(this, [key, page]);
this.updatePath();
return this.length;
};
path.goto = function(index) {
while (this.length - 1 > index) this.pop();
this.updatePath();
};
path.sidebar = function(key, page) {
while (this.length > 0) this.pop();
return this.push(key, page);
};
const leaderboardPage = document.createElement("div");
leaderboardPage.className = classes.leaderboardPage;
const leaderboardList = document.createElement("ul");
leaderboardList.className = classes.noScroll + " " + classes.leaderboardList;
leaderboardPage.append(leaderboardList);
const logsPage = document.createElement("div");
logsPage.className = classes.logsPage;
const logMessages = document.createElement("ul");
logMessages.className = classes.noScroll + " " + classes.logMessages;
const clearLogsButton = document.createElement("div");
clearLogsButton.className = classes.clearLogsButton;
clearLogsButton.innerHTML = `<i class="fas fa-ban" style="line-height: 1"></i>`;
logsPage.append(logMessages, clearLogsButton);
let leaderboardPath;
const Logs = {
connection: null,
standings: [],
data: {},
gamemodeData: {
gold: {
sort: "g",
},
hack: {
sort: "cr",
},
fish: {
sort: "w",
},
pirate: {
sort: "d",
},
defense2: {
sort: "d",
},
brawl: {
sort: "xp",
upgrades: {
egg: "Rapid Eggs",
nut: "Crazy Acorns",
slime: "Bouncing Slime",
jesterBall: "Juggling Spheres",
horseshoe: "Revolving Horseshoes",
shell: "Rebounding Shell",
pizza: "Boomerang Pizza",
banana: "Curving Banana",
arrow: "Speeding Arrows",
peacock: "Peacock Feathers",
bone: "Whirling Bones",
bee: "Buzzing Bees",
bubble: "Booming Bubbles",
card: "Slicing Cards",
laser: "Rapid-fire Lasers",
darkEnergy: "Dark Energy",
syrup: "Sticky Syrup",
birdFeather: "Flying Feathers",
},
},
dino: {
sort: "f",
},
royale: {
sort: "e",
},
defense: {
sort: "d",
},
cafe: {
sort: "ca",
},
factory: {
sort: "ca",
glitches: {
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"
},
},
racing: {
sort: "pr",
},
rush: {
sort: "bs",
},
classic: {
sort: "p",
},
tower: {},
kingdom: {},
toy: {
sort: "t",
sabotages: {
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"
},
},
},
exponents: ["⁰", "¹", "²", "³", "⁴", "⁵", "⁶", "⁷", "⁸", "⁹"],
formatNumber(input) {
const [number, exponent] = (input = parseFloat(input)).toLocaleString(undefined, {
notation: "engineering"
}).toLowerCase().split("e");
if (exponent < 15) return number + ["", "k", "M", "B", "T"][exponent / 3];
const [num, exp] = input.toLocaleString(undefined, {
notation: "scientific"
}).toLowerCase().split("e");
return num + " \xd7 10" + exp.split("").reduce((a, b) => a + Logs.exponents[b], "");
},
leaderboardCache: {},
createStandingElement(name) {
const element = document.createElement("li");
element.className = classes.standing;
element.innerText = name;
const blook = document.createElement("img");
blook.className = classes.standingBlook;
element.prepend(blook);
return (Logs.leaderboardCache[name] = element);
},
setLeaderboard(standings) {
if (standings.length > 0) leaderboardPath.style.display = "flex";
leaderboardList.innerHTML = "";
let place = 1;
let blookInfo;
for (let i = 0; i < standings.length; i++) {
const standing = standings[i];
const standingEl = Logs.leaderboardCache[standing.name] || Logs.createStandingElement(standing.name);
standingEl.firstChild.src = (blookInfo = Logs.blookData[Logs.data[standing.name]?.b || "Black"]).url;
standingEl.style.setProperty("--standingColor", blookInfo.color);
standingEl.dataset[datasets.value] = Logs.formatNumber(standing.value);
if (standings[i - 1]?.value != standings[i].value) place = i + 1;
standingEl.dataset[datasets.place] = place;
leaderboardList.append(standingEl);
}
},
blookData: null,
fetchBlooks() {
return (
Logs.blookData ??
new Promise((r) => {
var i = document.createElement("iframe");
i.style.display = "none";
var s = document.createElement("script");
s.type = "module";
s.src = document.querySelector("script[src*='ac.blooket.com']").src + "?" + Date.now();
const a = document.createElement("div");
a.id = "app";
let blooks = {};
document.body.appendChild(i);
let finish;
i.contentWindow.Object.prototype.hasOwnProperty.call = function(a, b) {
if (a[b]?.rarity && a in blooks == false) Object.assign(blooks, a);
finish ??= setTimeout(() => {
document.body.removeChild(i);
r((Logs.blookData = blooks));
});
return Object.prototype.hasOwnProperty.call(a, b);
};
i.contentDocument.body.appendChild(a);
i.contentDocument.body.appendChild(s);
})
);
},
async connect() {
try {
const stateNode = getStateNode();
if (!stateNode?.props?.liveGameController?._liveGameCode) return false;
Logs.connection = await stateNode.props.liveGameController.getDatabaseRef("c");
if (!Logs.connection) return false;
await Logs.fetchBlooks();
const gamemode = Logs.getGamemode();
Logs.connection.on("value", (snapshot) => {
const players = snapshot.val() || {};
let added;
if (!players || !(added = Logs.diffObjects(Logs.data, players))) return;
Logs.data = players;
if (Logs.gamemodeData[gamemode].sort) {
Logs.standings = Object.entries(players)
.map(([name, data]) => ({
name,
blook: data.b,
value: data[Logs.gamemodeData[gamemode].sort] || 0
}))
.sort((a, b) => b.value - a.value);
Logs.setLeaderboard(Logs.standings);
}
try {
let addedPlayer;
switch (gamemode) {
case "brawl":
for (const player in added) {
if (!(addedPlayer = added[player]).up) continue;
const upgrade = addedPlayer.up.split(":");
if (upgrade.length == 2 && upgrade[0] in Logs.gamemodeData.brawl.upgrades) Logs.addAlert(player, `upgraded ${Logs.gamemodeData.brawl.upgrades[upgrade[0]]} to level ${upgrade[1]}`);
}
break;
case "gold":
for (const player in added) {
if (!(addedPlayer = added[player]).tat) continue;
const [tat, amount] = addedPlayer.tat.split(":");
if (amount == "swap") Logs.addAlert(player, `just swapped ${document.querySelector("[src*='assets/candy']") ? "candy" : "gold"} with ${tat}`);
else Logs.addAlert(player, `just took ${Logs.formatNumber(parseInt(amount))} ${document.querySelector("[src*='assets/candy']") ? "candy" : "gold"} from ${tat}`);
}
break;
case "toy":
for (const player in added) {
if ((addedPlayer = added[player]).s) Logs.addAlert(player, `sabotaged with "${Logs.gamemodeData.toy.sabotages[addedPlayer.s]}"`);
else if (addedPlayer.tat) {
const [tat, amount] = addedPlayer.tat.split(":");
if (amount == "swap") Logs.addAlert(player, `just swapped toys with ${tat}`);
else Logs.addAlert(player, `just took ${Logs.formatNumber(parseInt(amount))} toy${amount == 1 ? "" : "s"} from ${tat}`);
}
}
break;
case "hack":
for (const player in added) {
if (!(addedPlayer = added[player]).tat) continue;
const [tat, amount] = addedPlayer.tat.split(":");
Logs.addAlert(player, `just took ${Logs.formatNumber(parseInt(amount))} crypto from ${tat}`);
}
break;
case "pirate":
for (const player in added) {
if (!(addedPlayer = added[player]).tat) continue;
const [tat, amount] = addedPlayer.tat.split(":");
Logs.addAlert(player, `just took ${Logs.formatNumber(parseInt(amount))} doubloons from ${tat}`);
}
break;
case "defense2":
for (const player in added) {
if (!(addedPlayer = added[player]).r) continue;
Logs.addAlert(player, `just completed Round ${addedPlayer.r}!`);
}
break;
case "fishing":
for (const player in added) {
if ((addedPlayer = added[player]).f == "Frenzy") Logs.addAlert(player, `just started a frenzy`);
else if (addedPlayer.s) Logs.addAlert(player, `just sent a ${addedPlayer.f} distraction`);
}
break;
case "dino":
for (const player in added) {
if (!(addedPlayer = added[player]).tat) continue;
const [tat, caught] = addedPlayer.tat.split(":");
if (caught == "true") Logs.addAlert(player, `just caught ${tat} CHEATING!`);
else Logs.addAlert(player, `investigated ${tat}`);
}
break;
case "cafe":
for (const player in added) {
if (!(addedPlayer = added[player]).up) continue;
const [upgrade, level] = addedPlayer.up.split(":");
if (level) Logs.addAlert(player, `upgraded ${upgrade} to level ${level}`);
}
break;
case "factory":
for (const player in added) {
if ((addedPlayer = added[player]).g) Logs.addAlert(player, `activated the ${Logs.gamemodeData.factory.glitches[addedPlayer.g]} glitch!`);
else if (addedPlayer.s) {
const [amount, synergy] = addedPlayer.s.split("-");
Logs.addAlert(player, `has a ${amount} ${synergy} synergy!`);
} else if (addedPlayer.t) Logs.addAlert(player, `now has 10 Blooks!`);
}
break;
}
} catch (e) {
console.error(e);
Logs.addLog("Error adding an alert", "red");
}
});
return true;
} catch (e) {
console.warn(e);
return false;
}
},
diffObjects(obj1, obj2) {
const changed = {};
for (const key in obj1) {
if (!(key in obj2)) continue;
if (typeof obj1[key] === "object" && typeof obj2[key] === "object") {
const recChanged = Logs.diffObjects(obj1[key], obj2[key]);
if (recChanged && Object.keys(recChanged).length !== 0) changed[key] = recChanged;
} else if (JSON.stringify(obj1[key]) !== JSON.stringify(obj2[key])) changed[key] = obj2[key];
}
for (const key in obj2)
if (!(key in obj1)) changed[key] = obj2[key];
if (Object.keys(changed).length == 0) return null;
return changed;
},
getGamemode() {
const gamemode = getStateNode().props?.client?.type;
if (typeof gamemode == "string") return gamemode.toLowerCase();
switch (window.location.pathname) {
case "/play/gold":
case "/play/gold/final":
case "/gold/play/landing":
return "gold";
case "/play/hack":
case "/play/hack/final":
case "/hack/play/landing":
return "hack";
case "/play/fishing":
case "/play/fishing/final":
case "/fish/play/landing":
return "fish";
case "/play/pirate":
case "/play/pirate/final":
case "/pirate/play/landing":
return "pirate";
case "/play/defense2/load":
case "/play/defense2":
case "/play/defense2/final":
case "/defense2/play/landing":
return "defense2";
case "/play/brawl/start":
case "/play/brawl/settings":
case "/play/brawl":
case "/play/brawl/final":
case "/brawl/play/landing":
return "brawl";
case "/play/dino":
case "/play/dino/final":
case "/dino/play/landing":
return "dino";
case "/play/battle-royale/match/preview":
case "/play/battle-royale/question":
case "/play/battle-royale/answer/sent":
case "/play/battle-royale/answer/result":
case "/play/battle-royale/match/result":
case "/play/battle-royale/final":
case "/royale/play/landing":
return "royale";
case "/defense/load":
case "/defense":
case "/defense/final":
case "/defense/play/landing":
return "defense";
case "/cafe/load":
case "/cafe":
case "/cafe/shop":
case "/cafe/final":
case "/cafe/play/landing":
return "cafe";
case "/play/factory":
case "/play/factory/settings":
case "/play/factory/start":
case "/play/factory/final":
case "/factory/play/landing":
return "factory";
case "/play/racing":
case "/play/racing/final":
case "/racing/play/landing":
return "racing";
case "/play/rush":
case "/play/rush/final":
case "/rush/play/landing":
return "rush";
case "/play/classic/get-ready":
case "/play/classic/question":
case "/play/classic/answer/sent":
case "/play/classic/answer/result":
case "/play/classic/standings":
case "/play/classic/final":
case "/classic/play/landing":
return "classic";
case "/tower/load":
case "/tower/start":
case "/tower/map":
case "/tower/battle":
case "/tower/rest":
case "/tower/risk":
case "/tower/shop":
case "/tower/victory":
case "/tower/final":
case "/tower/play/landing":
return "tower";
case "/kingdom/start":
case "/kingdom":
case "/kingdom/final":
case "/kingdom/play/landing":
return "kingdom";
case "/play/toy":
case "/play/toy/final":
case "/toy/play/landing":
return "toy";
}
return "";
},
sanitizer: document.createElement("div"),
sanitizeText(text) {
Logs.sanitizer.textContent = text;
return Logs.sanitizer.innerHTML;
},
addAlert(name, message) {
const element = document.createElement("li");
element.className = classes.logMessage;
const span = document.createElement("span");
Logs.lastLog.setTime(Date.now());
span.innerHTML = `<strong>${Logs.sanitizeText(name)}</strong> ${Logs.sanitizeText(message)}<span style="opacity: 50%; flex: 1; text-align: right;">${parseTime(Logs.lastLog)}</span>`;
let blook;
if ((blook = Logs.blookData?.[Logs.data[name].b])) {
const img = document.createElement("img");
img.src = blook.url;
span.prepend(img);
}
element.append(span);
logMessages.prepend(element);
},
lastLog: new Date(),
addLog(message, color) {
const element = document.createElement("li");
element.className = classes.logMessage;
const span = document.createElement("span");
if (color) span.style.color = color;
span.style.display = "flex";
Logs.lastLog.setTime(Date.now());
span.innerHTML = "[LOG] " + Logs.sanitizeText(message) + `<span style="opacity: 50%; flex: 1; text-align: right;">${parseTime(Logs.lastLog)}</span>`;
element.append(span);
logMessages.prepend(element);
},
interval: null,
};
if (window.location.host != "dashboard.blooket.com" && window.location.host != "blooket.com") Logs.interval = setInterval(() => Logs.connect().then((connected) => connected && clearInterval(Logs.interval)), 5000);
clearLogsButton.onclick = () => {
clearLogsButton.animate([{
rotate: "0deg"
}, {
rotate: "360deg"
}], {
duration: 750,
easing: "ease"
});
logMessages.innerHTML = "";
Logs.addLog("Cleared Logs");
};
// Helper function to create a function from user code
// Handles various input formats: function declarations, arrow functions, IIFEs, or raw code
function createFunctionFromCode(code, ...params) {
try {
// Trim the code
code = code.trim();
// Check if it's an IIFE (Immediately Invoked Function Expression)
// Pattern: (function(...) {...})() or ((...) => {...})() or (() => {...})()
const iifePattern = /^\(.*\)\(\);?$/s;
if (iifePattern.test(code)) {
// Wrap the IIFE in a function that will execute it when called
// This allows us to store the IIFE and run it later
return new Function(code);
}
// Check if it's a complete function definition (function(...) { ... })
if (code.startsWith('function')) {
// Extract the function by evaluating it
// Wrap in parentheses to make it an expression
return eval(`(${code})`);
}
// Check if it's an arrow function
if (code.includes('=>')) {
// Wrap in parentheses to make it an expression
return eval(`(${code})`);
}
// Otherwise, treat it as a function body
// If params are provided, use them
if (params.length > 0) {
return new Function(...params, code);
} else {
return new Function(code);
}
} catch (error) {
console.error('Error creating function from code:', error);
console.error('Code:', code);
// Return a no-op function on error
return function() {
console.error('Failed to execute custom module due to syntax error');
};
}
}
const cheats = {
global: {
img: "https://ac.blooket.com/dashclassic/assets/Blooket-M6jYh_hk.png",
name: "Global",
cheats: [{
name: "Auto Answer",
description: "Toggles auto answer on",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
if (stateNode.state.question.qType != "typing") {
if (stateNode.state.stage != "feedback" && !stateNode.state.feedback) {
let ind;
for (ind = 0; ind < Question.answers.length; ind++) {
let found = false;
for (let j = 0; j < Question.correctAnswers.length; j++)
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
if (found) break;
}
document.querySelectorAll("[class*='answerContainer']")[ind].click();
} else document.querySelector("[class*='feedback'], [id*='feedback']").firstChild.click();
} else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(Question.answers[0]);
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Highlight Answers",
description: "Toggles highlight answers on",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
let ind = 0;
while (ind < Question.answers.length) {
let found = false;
for (let j = 0; j < Question.correctAnswers.length; j++)
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
ind++;
document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.backgroundColor = found ? "rgb(0, 207, 119)" : "rgb(189, 15, 38)";
}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Subtle Highlight Answers",
description: "Toggles subtle highlight answers on",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
let ind = 0;
while (ind < Question.answers.length) {
let j = 0;
let found = false;
while (j < Question.correctAnswers.length) {
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
j++;
}
ind++;
if (found) document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.boxShadow = "unset";
}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
}, {
name: "Learn Auto Answer",
description: "Toggles Learn Auto Answer on. This version works in the modes that auto answer doesnt work in, but can only learn answers if you've seen them before.",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
(() => {
console.log("🧠 Learn Auto Answer v3.3\n");
if (!window.answerDatabase) {
window.answerDatabase = {};
}
function autoContinue() {
const feedbackContainer = document.querySelector('[class*="feedbackContainer"]');
const feedbackText = document.querySelector('[class*="feedbackText"]');
const isFeedback = feedbackContainer || (feedbackText && feedbackText.offsetParent !== null);
if (isFeedback) {
if (feedbackContainer) feedbackContainer.click();
else document.body.click();
const event = new KeyboardEvent('keydown', {
key: 'Enter', code: 'Enter', keyCode: 13, which: 13, bubbles: true
});
document.dispatchEvent(event);
}
}
function learn() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
wrappers.forEach(wrapper => {
const questionTextEl = wrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = wrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = wrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
const correctBtn = Array.from(wrapper.querySelectorAll('[class*="answerButton"]')).find(btn =>
btn.innerHTML.includes('fa-check') ||
(btn.style.backgroundColor && btn.style.backgroundColor.includes('rgb(139, 220, 111)')) ||
(btn.querySelector('[class*="answerFront"]') && btn.querySelector('[class*="answerFront"]').style.backgroundColor.includes('rgb(139, 220, 111)'))
);
if (correctBtn) {
const textEl = correctBtn.querySelector('[class*="answerText"]');
const mathEl = correctBtn.querySelector('[class*="mq-selectable"]');
const answer = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : null);
if (answer && !window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned (MC): "${question}" → "${answer}"`);
}
}
const rawTypingEls = Array.from(wrapper.querySelectorAll('[class*="typingFeedbackAnswer"]'));
const realTypingAnswers = rawTypingEls.filter(el => {
const cls = el.getAttribute('class') || "";
return !cls.includes('Answers') && !cls.includes('Icon');
});
if (realTypingAnswers.length > 0) {
const answer = realTypingAnswers[0].textContent.trim();
if (!window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned (Typing): "${question}" → "${answer}"`);
}
}
});
}
function answer() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
if (wrappers.length === 0) return;
let activeWrapper = wrappers[wrappers.length - 1];
const questionTextEl = activeWrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = activeWrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = activeWrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
if (window.answerDatabase[question]) {
const knownAnswer = window.answerDatabase[question][0];
const buttons = activeWrapper.querySelectorAll('[class*="answerButton"]');
for (const btn of buttons) {
const textEl = btn.querySelector('[class*="answerText"]');
const mathEl = btn.querySelector('[class*="mq-selectable"]');
const btnText = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : "");
if (btnText === knownAnswer && !btn.className.includes('Disabled')) {
console.log(`🎯 Answering (MC): "${question}"`);
btn.click();
return;
}
}
const input = activeWrapper.querySelector('input[class*="typingAnswerInput"]');
if (input && !input.disabled) {
if (input.value !== knownAnswer) {
console.log(`🎯 Typing: "${knownAnswer}"`);
const setter = Object.getOwnPropertyDescriptor(window.HTMLInputElement.prototype, "value").set;
setter.call(input, knownAnswer);
input.dispatchEvent(new Event('input', { bubbles: true }));
input.dispatchEvent(new Event('change', { bubbles: true }));
}
const submitBtn = activeWrapper.querySelector('button[class*="typingAnswerButton"]');
if (submitBtn && (!submitBtn._lastClick || Date.now() - submitBtn._lastClick > 200)) {
submitBtn.click();
submitBtn._lastClick = Date.now();
}
}
}
}
this.data = setInterval(() => {
autoContinue();
learn();
answer();
}, 50);
console.log("✅ Script Active.");
})();
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
}, {
name: "Learn Highlight Answer",
description: "Toggles Learn Highlight Answer on. This version works in the modes that highlight answers doesnt work in, but can only learn answers if you've seen them before.",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
(() => {
console.log("🎨 Highlight Answers Active (Green = Correct, Red = Wrong)\n");
if (!window.answerDatabase) {
window.answerDatabase = {};
}
function autoContinue() {
const feedbackContainer = document.querySelector('[class*="feedbackContainer"]');
const feedbackText = document.querySelector('[class*="feedbackText"]');
const isFeedback = feedbackContainer ||
(feedbackText && feedbackText.offsetParent !== null);
if (isFeedback) {
if (feedbackContainer) {
feedbackContainer.click();
} else {
document.body.click();
}
const event = new KeyboardEvent('keydown', {
key: 'Enter',
code: 'Enter',
keyCode: 13,
which: 13,
bubbles: true
});
document.dispatchEvent(event);
}
}
function learn() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
wrappers.forEach(wrapper => {
const questionTextEl = wrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = wrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = wrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
const correctBtn = Array.from(wrapper.querySelectorAll('[class*="answerButton"]')).find(btn =>
btn.innerHTML.includes('fa-check') ||
(btn.style.backgroundColor && btn.style.backgroundColor.includes('rgb(139, 220, 111)')) ||
(btn.querySelector('[class*="answerFront"]') && btn.querySelector('[class*="answerFront"]').style.backgroundColor.includes('rgb(139, 220, 111)'))
);
if (correctBtn) {
const textEl = correctBtn.querySelector('[class*="answerText"]');
const mathEl = correctBtn.querySelector('[class*="mq-selectable"]');
const answer = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : null);
if (answer && !window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned (MC): "${question}" → "${answer}"`);
}
}
const rawTypingEls = Array.from(wrapper.querySelectorAll('[class*="typingFeedbackAnswer"]'));
const realTypingAnswers = rawTypingEls.filter(el => {
const cls = el.getAttribute('class') || "";
return !cls.includes('Answers') && !cls.includes('Icon');
});
if (realTypingAnswers.length > 0) {
const answer = realTypingAnswers[0].textContent.trim();
if (!window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned (Typing): "${question}" → "${answer}"`);
}
}
});
}
function highlight() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
if (wrappers.length === 0) return;
const activeWrapper = wrappers[wrappers.length - 1];
if (activeWrapper.className.includes('slideOut')) return;
const questionTextEl = activeWrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = activeWrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = activeWrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
if (window.answerDatabase[question]) {
const knownAnswer = window.answerDatabase[question][0];
const buttons = activeWrapper.querySelectorAll('[class*="answerButton"]');
if (buttons.length > 0) {
buttons.forEach(btn => {
const textEl = btn.querySelector('[class*="answerText"]');
const mathEl = btn.querySelector('[class*="mq-selectable"]');
const btnText = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : "");
const front = btn.querySelector('[class*="answerFront"]');
const back = btn.querySelector('[class*="answerBack"]');
const correctColor = '#00ff00';
const wrongColor = '#ff0000';
if (btnText === knownAnswer) {
if (front) {
front.style.backgroundColor = correctColor;
front.style.color = 'black';
}
if (back) back.style.backgroundColor = '#00cc00';
} else if (btnText) {
if (front) {
front.style.backgroundColor = wrongColor;
front.style.opacity = '0.7';
}
if (back) back.style.backgroundColor = '#cc0000';
}
});
}
const input = activeWrapper.querySelector('input[class*="typingAnswerInput"]');
if (input) {
input.setAttribute('placeholder', `ANSWER: ${knownAnswer}`);
const subHeader = activeWrapper.querySelector('[class*="typingAnswerSubheader"]');
if (subHeader) {
subHeader.textContent = `ANSWER: ${knownAnswer}`;
subHeader.style.color = '#00ff00';
subHeader.style.fontWeight = 'bold';
subHeader.style.fontSize = '20px';
}
}
}
}
this.data=setInterval(() => {
autoContinue();
learn();
highlight();
}, 100);
console.log("✅ Highlighting Active. Play manually to populate database.");
})();
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
}, {
name: "Learn Subtle Highlight Answers",
description: "Toggles auto answer on",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
(() => {
console.log("🕵️ Subtle Highlight Active (Lighter Shadow = Correct)\n");
if (!window.answerDatabase) {
window.answerDatabase = {};
}
function lightenColor(color) {
const rgb = color.match(/\d+/g);
if (!rgb) return color;
const r = Math.round(parseInt(rgb[0]) + (255 - parseInt(rgb[0])) * 0.1);
const g = Math.round(parseInt(rgb[1]) + (255 - parseInt(rgb[1])) * 0.1);
const b = Math.round(parseInt(rgb[2]) + (255 - parseInt(rgb[2])) * 0.1);
return `rgb(${r}, ${g}, ${b})`;
}
function autoContinue() {
const feedbackContainer = document.querySelector('[class*="feedbackContainer"]');
const feedbackText = document.querySelector('[class*="feedbackText"]');
const isFeedback = feedbackContainer ||
(feedbackText && feedbackText.offsetParent !== null);
if (isFeedback) {
if (feedbackContainer) {
feedbackContainer.click();
} else {
document.body.click();
}
const event = new KeyboardEvent('keydown', {
key: 'Enter',
code: 'Enter',
keyCode: 13,
which: 13,
bubbles: true
});
document.dispatchEvent(event);
}
}
function learn() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
wrappers.forEach(wrapper => {
const questionTextEl = wrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = wrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = wrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
const correctBtn = Array.from(wrapper.querySelectorAll('[class*="answerButton"]')).find(btn =>
btn.innerHTML.includes('fa-check') ||
(btn.style.backgroundColor && btn.style.backgroundColor.includes('rgb(139, 220, 111)')) ||
(btn.querySelector('[class*="answerFront"]') && btn.querySelector('[class*="answerFront"]').style.backgroundColor.includes('rgb(139, 220, 111)'))
);
if (correctBtn) {
const textEl = correctBtn.querySelector('[class*="answerText"]');
const mathEl = correctBtn.querySelector('[class*="mq-selectable"]');
const answer = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : null);
if (answer && !window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned: "${question}" → "${answer}"`);
}
}
const rawTypingEls = Array.from(wrapper.querySelectorAll('[class*="typingFeedbackAnswer"]'));
const realTypingAnswers = rawTypingEls.filter(el => {
const cls = el.getAttribute('class') || "";
return !cls.includes('Answers') && !cls.includes('Icon');
});
if (realTypingAnswers.length > 0) {
const answer = realTypingAnswers[0].textContent.trim();
if (!window.answerDatabase[question]) {
window.answerDatabase[question] = [answer];
console.log(`✓ Learned: "${question}" → "${answer}"`);
}
}
});
}
function highlight() {
const wrappers = document.querySelectorAll('[class*="questionWrapper"]');
if (wrappers.length === 0) return;
const activeWrapper = wrappers[wrappers.length - 1];
if (activeWrapper.className.includes('slideOut')) return;
const questionTextEl = activeWrapper.querySelector('[class*="questionText"]');
if (!questionTextEl) return;
let questionMedia = activeWrapper.querySelector('[class*="questionImage"]');
let qMediaSrc = questionMedia ? questionMedia.src : "none";
let questionMath = activeWrapper.querySelector('[class*="mq-selectable"]');
let qMathText = questionMath ? questionMath.innerText.trim() : "none";
const question = questionTextEl.textContent.trim() + " " + qMediaSrc + " " + qMathText;
if (window.answerDatabase[question]) {
const knownAnswer = window.answerDatabase[question][0];
const buttons = activeWrapper.querySelectorAll('[class*="answerButton"]');
if (buttons.length > 0) {
buttons.forEach(btn => {
const textEl = btn.querySelector('[class*="answerText"]');
const mathEl = btn.querySelector('[class*="mq-selectable"]');
const btnText = textEl ? textEl.textContent.trim() : (mathEl ? mathEl.innerText.trim() : "");
const back = btn.querySelector('[class*="answerBack"]');
if (back && btnText === knownAnswer) {
const currentColor = window.getComputedStyle(back).backgroundColor;
back.style.backgroundColor = lightenColor(currentColor);
}
});
}
const input = activeWrapper.querySelector('input[class*="typingAnswerInput"]');
if (input) {
input.setAttribute('placeholder', knownAnswer);
}
}
}
this.data = setInterval(() => {
autoContinue();
learn();
highlight();
}, 100);
console.log("✅ Subtle Highlight Active.");
})();
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Freeze Leaderboard",
description: "Freezes the leaderboard on the host's screen",
type: "toggle",
enabled: !1,
data: null,
run: function() {
var e = Object.values(function e(t = document.querySelector("#app")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner.stateNode;
if (this.enabled)
this.enabled = !1, clearInterval(this.data), this.data = null, e.props.liveGameController.removeVal(`c/${e.props.client.name}/tat`);
else {
this.enabled = !0;
let t = () => {
e.props.liveGameController.setVal({
path: `c/${e.props.client.name}/tat/Freeze`,
val: "freeze"
})
};
this.data = setInterval(t, 25)
}
}
}, {
name: "Anti Kick",
description: "Prevents the host from kicking you, Although cheats stop working and you can't win.",
type: "toggle",
enabled: false,
data: null,
run: function() {
const stateNode = getStateNode();
const lgc = stateNode?.props?.liveGameController;
if (!lgc) return alert("Not in a game.");
if (!this.enabled) {
// TURN ON
this.enabled = true;
const playerName = stateNode.props.client.name;
const savedBlook = stateNode.props.client.blook;
this.data = setInterval(() => {
lgc.getDatabaseRef("c").once("value", (snap) => {
const players = snap.val() || {};
// Host kicked you → your entry removed
if (!players[playerName]) {
lgc.setVal({
path: `c/${playerName}`,
val: {
n: playerName,
b: savedBlook
}
});
}
});
}, 500);
} else {
// TURN OFF
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
}
}, {
name: "Percent Auto Answer",
description: "Answers questions correctly or incorrectly depending on the goal grade given (Disable and re-enable to update goal)",
inputs: [{
name: "Target Grade",
type: "number",
}, ],
type: "toggle",
enabled: false,
data: null,
run: function(target) {
if (!this.enabled) {
this.enabled = true;
const stateNode = getStateNode();
this.data = setInterval(
(TARGET) => {
try {
const question = stateNode.state.question || stateNode.props.client.question;
if (stateNode.state.stage == "feedback" || stateNode.state.feedback) return document.querySelector('[class*="feedback"], [id*="feedback"]')?.firstChild?.click?.();
else if (document.querySelector("[class*='answerContainer']") || document.querySelector("[class*='typingAnswerWrapper']")) {
let correct = 0,
total = 0;
for (let corrects in stateNode.corrects) correct += stateNode.corrects[corrects];
for (let incorrect in stateNode.incorrects) total += stateNode.incorrects[incorrect];
total += correct;
const yes = total == 0 || Math.abs(correct / (total + 1) - TARGET) >= Math.abs((correct + 1) / (total + 1) - TARGET);
if (stateNode.state.question.qType != "typing") {
const answerContainers = document.querySelectorAll("[class*='answerContainer']");
for (let i = 0; i < answerContainers.length; i++) {
const contains = question.correctAnswers.includes(question.answers[i]);
if (yes == contains) return answerContainers[i]?.click?.();
}
answerContainers[0].click();
} else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(yes ? question.answers[0] : Math.random().toString(36).substring(2));
}
} catch {}
},
100,
(target ?? 100) / 100
);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Auto Answer",
description: "Click the correct answer for you",
run: function() {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
if (stateNode.state.question.qType != "typing") {
if (stateNode.state.stage != "feedback" && !stateNode.state.feedback) {
let ind;
for (ind = 0; ind < Question.answers.length; ind++) {
let found = false;
for (let j = 0; j < Question.correctAnswers.length; j++)
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
if (found) break;
}
document.querySelectorAll("[class*='answerContainer']")[ind].click();
} else document.querySelector("[class*='feedback'], [id*='feedback']").firstChild.click();
} else Object.values(document.querySelector("[class*='typingAnswerWrapper']"))[1].children._owner.stateNode.sendAnswer(Question.answers[0]);
},
},
{
name: "Highlight Answers",
description: "Colors answers to be red or green highlighting the correct ones",
run: function() {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
let ind = 0;
while (ind < Question.answers.length) {
let found = false;
for (let j = 0; j < Question.correctAnswers.length; j++)
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
ind++;
document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.backgroundColor = found ? "rgb(0, 207, 119)" : "rgb(189, 15, 38)";
}
},
},
{
name: "Free Folder!",
description: "Gives you plus perks like folders, does not unlock plus gamemodes! (ONLY WORKS ON THE ~MY SETS~ PAGE!)",
run: function () {
const reactHandler = () => Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner.stateNode;
const component = reactHandler();
if (!component) return console.error("React component not found!");
component.getIsPlus = e => e();
component.plus = true;
if (component.props && component.props.user && component.props.user.data) {
component.props.user.data.plan = "Plus";
component.props.user.data.hasPlus = true;
component.props.user.data.planName = "Plus";
}
component.setState({
hasPlus: true,
noFolder: false,
noMerge: false,
copying: false
});
console.log("Folders unlocked!");
},
},{
name: "Simulate Unlock",
description: "Simulates unlocking a certain blook",
inputs: [{
name: "Blook (Case Sensitive)"
}],
run: (unlockedBlook) => {
const stateNode = Object.values(document.querySelector("#app>div>div"))[1].children[0]._owner.stateNode;
stateNode.setState({
loadingPack: !1,
openPack: !0,
unlockedBlook,
newUnlock: !0,
canOpen: !1
});
setTimeout(() => stateNode.setState({
canOpen: !0
}), 200);
}
}, {
name: "Simulate Pack",
description: "Simulates unlocking a pack",
inputs: [{
name: "Pack",
type: "options",
options: () => [...document.querySelector("[class*=packsWrapper]")?.children]?.map(e => e.children[0].children[0].alt)
}],
run: async (packName) => {
let i = document.createElement('iframe');
document.body.append(i);
const alert = i.contentWindow.alert.bind(window);
i.remove();
if (window.location.pathname !== "/market") {
alert("You must be on the market page to run this cheat!");
return;
}
const stateNode = Object.values(document.querySelector("#app>div>div"))[1].children[0]._owner.stateNode;
const getProbs = (pack) => (new Promise(res => {
if (!Array.prototype.map2) {
Array.prototype.map2 = Array.prototype.map;
}
Array.prototype.map = function() {
if (typeof this[0]?.[1] == "number") {
res(this);
Array.prototype.map = Array.prototype.map2;
}
return Array.prototype.map2.apply(this, arguments);
}
var a = new(stateNode.constructor)();
a.state.currentPack = pack;
a.render();
res(null);
}));
async function pickRandom(pack) {
let probs = (await getProbs(pack));
const choice = pickW(probs.map(e => e[1]));
return probs[choice];
}
function pickW(a) {
let v = 0;
let sum = [];
const rand = Math.floor(Math.random() * a.reduce((a, b) => a + b, 0));
a.forEach(e => (sum.push(v), v += e));
return sum.map(e => rand < e).findLastIndex(e => e ? 0 : 1);
}
stateNode.setState({
loadingPack: !1,
openPack: !0,
unlockedBlook: (await pickRandom(packName))[0],
newUnlock: !0,
canOpen: !1
});
setTimeout(() => stateNode.setState({
canOpen: !0
}), 200);
}
}, {
name: "Spam Buy Blooks",
description: "Opens a box an amount of times",
inputs: [{
name: "Box",
type: "options",
options: () =>
Array.from(document.querySelectorAll("[class*='packsWrapper'] > div")).reduce((a, b) => {
b.querySelector("[class*='blookContainer'] > img") || a.push(b.querySelector("[class*='packImgContainer'] > img").alt);
return a;
}, []),
},
{
name: "Amount",
type: "number",
},
{
name: "Show Unlocks",
type: "options",
options: [{
name: "Show Unlocks",
value: true,
},
{
name: "Don't Show Unlocks",
value: false,
},
],
},
],
run: async function(box, amountToOpen, alertBlooks) {
if (window.location.pathname.startsWith("/market")) {
const stateNode = getStateNode();
const prices = Array.prototype.reduce.call(
document.querySelectorAll("[class*='packsWrapper'] > div"),
(a, b) => {
b.querySelector("[class*='blookContainer'] > img") || (a[b.querySelector("[class*='packImgContainer'] > img").alt] = parseInt(b.querySelector("[class*='packBottom']").textContent));
return a;
}, {}
);
box = box
.split(" ")
.map((str) => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase())
.join(" ");
const cost = prices[box];
if (!cost) return alert("I couldn't find that box!");
const canOpen = Math.floor(stateNode.state.tokens / cost);
if (canOpen <= 0) return alert("You do not have enough tokens!");
const amount = Math.min(canOpen, amountToOpen || 0);
const blooks = {},
now = Date.now();
for (let i = 0; i < amount; i++) {
await stateNode.buyPack(true, box);
blooks[stateNode.state.unlockedBlook] ||= 0;
blooks[stateNode.state.unlockedBlook]++;
stateNode.startOpening();
clearTimeout(stateNode.openTimeout);
const rarity = stateNode.state.purchasedBlookRarity;
stateNode.setState({
canOpen: true,
currentPack: "",
opening: alertBlooks,
doneOpening: alertBlooks,
openPack: alertBlooks
});
clearTimeout(stateNode.canOpenTimeout);
if (rarity == "Chroma") break;
}
await new Promise((r) => setTimeout(r));
alert(
`(${Date.now() - now}ms) Results:\n${Object.entries(blooks)
.map(([blook, amount]) => ` ${blook} ${amount}`)
.join(`\n`)}`
);
} else alert("This can only be ran in the Market page.");
},
},
{
name: "Bypass Filter",
description: "Bypasses the name filter",
inputs: [{
name: "Text",
type: "text",
}],
run: function(e) {
var t,
a,
o;
let r;
a = function e(t) {
for (var a = t.split(""), o = "", r = 0; r < a.length; r++)
o += "\xad" + a[r];
return o
}
(t = e),
r = document.createElement("iframe"),
document.body.appendChild(r),
window.alert = r.contentWindow.alert.bind(r.contentWindow),
(o = document.createElement("textarea")).value = a,
o.style.position = "fixed",
o.style.top = 0,
o.style.left = 0,
o.style.opacity = 0,
document.body.appendChild(o),
o.select(),
document.execCommand("copy"),
alert("Bypassed text copied to clipboard!"),
r.remove(),
document.body.removeChild(o)
}
}, {
name: "Use any Banner",
description: "Unlocked all banners",
inputs: [{
name: "Banner",
type: "options",
options: Object.entries({
Starter: "starter",
Fire: "fire",
"Tech Chip": "techChip",
Shamrocks: "shamrocks",
"Orange Ice Pop": "orangeIcePop",
Slime: "slime",
Sushi: "sushi",
"Falling Blocks": "fallingBlocks",
Racetrack: "racetrack",
"Football Field": "footballField",
"Ice Cream Sandwich": "iceCreamSandwich",
"Winter Landscape": "winterLandscape",
Leaves: "leaves",
"Music Class": "musicClass",
"Science Class": "scienceClass",
"Art Class": "artClass",
Clockwork: "clockwork",
"Hockey Rink": "hockeyRink",
"Outer Space": "outerSpace",
"Soccer Field": "soccerField",
Ice: "ice",
"Toaster Pastry": "toasterPastry",
"Fish Tank": "fishTank",
Theater: "theater",
Farm: "farm",
Spooky: "spooky",
"Spooky Cat": "spookyCat",
"Spooky Window": "spookyWindow",
Frankenstein: "frankenstein",
Ghosts: "ghosts",
Mummy: "mummy",
Spiders: "spiders",
Coffin: "coffin",
Pumpkins: "pumpkins",
"Christmas Tree": "christmasTree",
Chalkboard: "chalkboard",
Balloons: "balloons",
Skateboard: "skateboard",
Sunset: "sunset",
Tiger: "tiger",
"Pirate Map": "pirateMap",
Pencil: "pencil",
"Road Sign": "roadSign",
"Corn Dog": "cornDog",
Leaf: "leaf",
"Chili Pepper": "chiliPepper",
"Love Letter": "loveLetter",
Gifts: "gifts",
"Winter Train": "winterTrain",
"Winter Drive": "winterDrive",
Workbench: "workbench",
Harvest: "harvest",
Chocolate: "chocolate",
"Fall Picnic": "fallPicnic",
Bookshelf: "bookshelf",
"Easter Pattern": "easterPattern",
Carrot: "carrot",
"Easter Field": "easterField",
Garden: "garden",
Bakery: "bakery",
"Gummy Worm": "gummyWorm",
"Basketball Court": "basketballCourt",
"Flying Kite": "flyingKite",
"Hot Dog": "hotDog",
"Japanese Garden": "japaneseGarden",
Sandwich: "sandwich",
Ruler: "ruler",
"Ball Pit": "ballPit",
"Xylophone": "xylophone",
"Holiday Lights": "holidayLights",
"Ice Cream Truck": "iceCreamTruck",
"Holiday Gift Wrap": "holidayGiftWrap",
"Winter Sweater": "winterSweater",
"Holiday Ornaments": "holidayOrnaments",
Watermelon: "watermelon",
Baguette: "baguette",
Rollerblades: "rollerblades",
Surfboard: "surfboard",
Cookout: "cookout",
Comic: "comic",
Crayon: "crayon",
Lightning: "lightning",
Baseball: "baseball",
"Shamrock Coins": "shamrockCoins",
"End Of The Rainbow": "endRainbow",
"Easter Field": "easterField",
Marker: "marker",
Pizza: "pizza",
Leaf: "leaf",
"Alphabet Soup": "alphabetSoup"
}).map(([e, t]) => ({
name: e,
value: t
}))
}],
run: function(e) {
var t = document.createElement("iframe");
function a() {
return Object.values(document.querySelector("#app>div>div"))[1].children[0]._owner
}
document.head.appendChild(t),
window.alert = t.contentWindow.alert.bind(window),
window.prompt = t.contentWindow.prompt.bind(window),
t.remove(),
a().stateNode.props.liveGameController.setVal({
path: "c/" + a().stateNode.props.client.name + "/bg",
val: e
})
}
}, {
name: "Change Blook Ingame",
description: "Changes your blook",
inputs: [{
name: "Blook (case sensitive)",
type: "string",
}, ],
run: function(blook) {
let {
props
} = getStateNode();
props.liveGameController.setVal({
path: `c/${props.client.name}/b`,
val: (props.client.blook = blook)
});
},
},
{
name: "Free Player Slots",
description: "Allows more players to join if the game is full",
run: async () => {
let i = document.createElement('iframe');
document.body.append(i);
const alert = i.contentWindow.alert.bind(window);
i.remove();
const stateNode = Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner.stateNode;
const players = await stateNode.props.liveGameController.getDatabaseVal("c");
let freed = 0;
if (!stateNode.state.blockedUsers) {
stateNode.state.blockedUsers = [];
}
async function wait(time) {
return new Promise(e => {
setTimeout(e, time);
});
}
async function blockUser(name) {
if (stateNode.state.blockedUsers.includes(name)) {
return;
}
const res = await fetch("https://fb.blooket.com/c/firebase/block", {
headers: {
"Content-Type": "application/json"
},
method: "POST",
body: JSON.stringify({
g: stateNode.props.host.id,
u: name
}),
credentials: "include"
});
if (res.status !== 200) {
return;
}
stateNode.state.blockedUsers.push(name);
freed++;
if (freed % parseInt("15") == 0) {
await wait(600);
}
C.alerts?.[0].addLog("Freed user: " + name);
}
for (let i in players) {
await blockUser(i);
}
alert(`Freed slots: ${freed}`);
}
}, {
name: "Get Daily Rewards",
description: "Gets max daily tokens and xp",
run: async function() {
if (!window.location.href.includes("play.blooket.com")) alert("This cheat only works on play.blooket.com, opening a new tab."), window.open("https://play.blooket.com/");
else {
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)];
const rand = (l, h) => Math.floor(Math.random() * (h - l + 1)) + l;
const {
t
} = await fetch("https://play.blooket.com/api/playersessions/solo", {
body: JSON.stringify({
gameMode: "Factory",
questionSetId: gameId
}),
method: "POST",
credentials: "include",
})
.then((x) => x.json())
.catch(() => alert("There was an error creating a solo game."));
await fetch("https://play.blooket.com/api/playersessions/landings", {
body: JSON.stringify({
t
}),
method: "POST",
credentials: "include",
}).catch(() => alert("There was an error when landing."));
await fetch("https://play.blooket.com/api/playersessions/questions?t=" + t, {
credentials: "include"
});
await fetch("https://play.blooket.com/api/gamequestionsets?gameId=" + gameId, {
credentials: "include"
});
await fetch("https://play.blooket.com/api/users/factorystats", {
body: JSON.stringify({
t,
place: 1,
cash: rand(10000000, 100000000),
playersDefeated: 0,
correctAnswers: rand(500, 2000),
upgrades: rand(250, 750),
blookUsed: "Chick",
nameUsed: "You",
mode: "Time-Solo"
}),
method: "PUT",
credentials: "include",
}).catch(() => alert("There was an error when spoofing stats."));
await fetch("https://play.blooket.com/api/users/add-rewards", {
body: JSON.stringify({
t,
addedTokens: 500,
addedXp: 300
}),
method: "PUT",
credentials: "include",
})
.then((x) => x.json())
.then(({
dailyReward
}) => alert(`Added max tokens and xp, and got ${dailyReward} daily wheel tokens!`))
.catch(() => alert("There was an error when adding rewards."));
}
},
},
{
name: "Blooket Bot",
description: "Opens Blooket Bot",
run: function() {
function getGameCode() {
const appDiv = document.querySelector('#app>div>div');
if (appDiv) {
const reactComponent = Object.values(appDiv)[1]?.children[0]?._owner;
return reactComponent?.stateNode?.props?.client?.hostId || null;
}
return null;
}
const gameCode = getGameCode();
const url = gameCode ? "https://blooketbot.schoolcheats.net/" + gameCode : "https://blooketbot.schoolcheats.net/";
window.open(url, "_blank", "width=500,height=500,resizable=yes,scrollbars=yes,status=yes");
}
}, {
name: "Blooket Stream Finder",
description: "Opens Stream Finder",
run: function() {
function getGameCode() {
const appDiv = document.querySelector('#app>div>div');
if (appDiv) {
const reactComponent = Object.values(appDiv)[1]?.children[0]?._owner;
return reactComponent?.stateNode?.props?.client?.hostId || null;
}
return null;
}
const gameCode = getGameCode();
const url = gameCode ? "https://0alter0.github.io/blooketstreamfinderV2/" + gameCode : "https://0alter0.github.io/blooketstreamfinderV2/";
window.open(url, "_blank", "width=500,height=500,resizable=yes,scrollbars=yes,status=yes");
}
}, {
name: "Open Chat (Global)",
description: "Opens The X-GUI Chat, Not Ingame",
run: function() {
window.open(
"https://hack.chat/?xgui",
"_blank",
"width=500,height=500,resizable=yes,scrollbars=yes,status=yes"
);
}
}, {
name: "Open Chat (Ingame)",
description: "Opens X-GUI Ingame Chat",
run: function() {
(function() {
function getGameCode() {
const appDiv = document.querySelector('#app>div>div');
if (appDiv) {
const reactComponent = Object.values(appDiv)[1]?.children[0]?._owner;
return reactComponent?.stateNode?.props?.client?.hostId || null;
}
return null;
}
function getGameCodeFromURL() {
const parts = window.location.pathname.split('/').filter(Boolean);
return parts.length >= 3 ? parts[0] : null;
}
let gameCode = getGameCode();
if (!gameCode) {
gameCode = getGameCodeFromURL();
}
const url = gameCode ?
"https://hack.chat/?xgui" + gameCode :
"https://hack.chat/?xgui";
window.open(
url,
"_blank",
"width=500,height=500,resizable=yes,scrollbars=yes,status=yes"
);
})();
}
}, {
name: "Crash Game (Gold Quest, Crypto, Frenzy)",
description: "Crashes the host's game",
run: function() {
var e = Object.values(function e(t = document.querySelector("#app")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner.stateNode;
e.props.liveGameController.setVal({
path: `c/${e.props.client.name}/b/toString`,
val: "Crashed"
})
}
},{
name: "Universal Game Crasher",
description: "Crashes the host's game. Works only on Enter Nickname menu or if you have the extension. And if your in Gold Quest, Crypto, Frenzy then it will crash when the game starts.",
run: async function() {
'use strict';
const wait = (ms) => new Promise(resolve => setTimeout(resolve, ms));
async function crashGame() {
await wait(500);
const nameInput = document.querySelector('.Form_longInput__Kyk9e');
const submitButton = document.querySelector('.FormSubmitButton_submitButton__MK2LJ');
if (nameInput && submitButton) {
await wait(200);
nameInput.value = "toString";
nameInput.dispatchEvent(new Event('input', { bubbles: true }));
await wait(100);
submitButton.click();
}
}
const onPlayPage = window.location.href.includes('play.blooket.com/play');
if (onPlayPage) {
await crashGame();
} else {
await wait(500);
const nameInput = document.querySelector('.Form_longInput__Kyk9e');
const submitButton = document.querySelector('.FormSubmitButton_submitButton__MK2LJ');
if (!nameInput || !submitButton) {
window.postMessage({ type: "FROM_PAGE_CRASH_GAME" }, "*");
} else {
await crashGame();
}
}
}
},
{
name: "Use Any Blook",
description: "Allows you to play as any blook",
run: function() {
const lobby = window.location.pathname.startsWith("/play/lobby"),
dashboard = !lobby && window.location.pathname.startsWith("/blooks");
if (dashboard) {
let key = "konzpack",
propCall = Object.prototype.hasOwnProperty.call;
let webpack = webpackChunk_N_E.push([
[key],
{
[key]: () => {}
},
function(func) {
Object.prototype.hasOwnProperty.call = function() {
Object.defineProperty(arguments[0], key, {
set: () => {},
configurable: true
});
return (Object.prototype.hasOwnProperty.call = propCall).apply(this, arguments);
};
return func;
},
]);
const blookData = webpack(4927).nK;
const blooksHook = Object.values(document.querySelector("[class*=BlooksWrapper_content]"))[0].return.memoizedState.next;
const showBlooks = blooksHook.memoizedState;
const seen = {},
userBlooks = [],
prices = {
Uncommon: 5,
Rare: 20,
Epic: 75,
Legendary: 200,
Chroma: 300,
Unique: 350,
Mystical: 1000,
};
for (const data of blooksHook.next.memoizedState) {
userBlooks.push(data);
seen[data.blook] = true;
}
for (const blook in blookData) {
if (blookData[blook].rarity != "Common" && !seen[blook])
userBlooks.push({
blook,
quantity: 1,
sellPrice: prices[blookData[blook].rarity],
});
}
blooksHook.next.queue.dispatch(userBlooks);
blooksHook.queue.dispatch(!showBlooks);
setTimeout(() => blooksHook.queue.dispatch(showBlooks), 1);
} else if (lobby) getStateNode().setState({
unlocks: {
includes: () => !0
}
});
else alert("This only works in lobbies or the dashboard blooks page.");
},
},
{
name: "Every Answer Correct",
description: "Sets every answer to be correct",
run: function() {
const stateNode = getStateNode();
for (let i = 0; i < stateNode.freeQuestions.length; i++) {
stateNode.freeQuestions[i].correctAnswers = stateNode.freeQuestions[i].answers;
stateNode.questions[i].correctAnswers = stateNode.questions[i].answers;
stateNode.props.client.questions[i].correctAnswers = stateNode.questions[i].answers;
}
try {
stateNode.forceUpdate();
} catch {}
},
},
{
name: "Remove all Taken Blooks",
description: "Removes all taken blooks, allowing you to use any taken blook. Only works in lobby.",
run: function() {
const stateNode = Object.values(document.querySelector("#app>div>div"))[1].children[0]._owner.stateNode;
stateNode.setState({
takenBlooks: {
includes: e => !1
}
});
stateNode.setState = function(a, b) {
if (a?.takenBlooks) {
return;
}
stateNode.updater.enqueueSetState(stateNode, a, b, "setState");
}
}
}, {
name: "Kick All Players HOST ONLY",
description: "Kicks all players from your game.",
run: function() {
(async function() {
const app = document.querySelector('#app>div>div');
if (!app) return;
const sn = Object.values(app)[1]?.children?.[0]?._owner?.stateNode;
if (!sn || !sn.props?.liveGameController) return;
const controller = sn.props.liveGameController;
const db = await controller.getDatabaseVal("");
if (!db || !db.c) return;
// Mark all players as kicked
controller.setVal({
path: "bu",
val: Object.keys(db.c).reduce(
(acc, id) => (acc[id] = 1, acc),
db.bu ? db.bu : {}
)
});
// Clear player list
controller.setVal({
path: "c",
val: {}
});
})();
}
}, {
name: "Enable Mobile Hosting",
description: "Makes it so that you can host on mobile",
run: function() {
(function() {
var metaViewport = document.querySelector('meta[name="viewport"]');
if (metaViewport) {
metaViewport.parentNode.removeChild(metaViewport);
}
var newMetaViewport = document.createElement('meta');
newMetaViewport.name = 'viewport';
newMetaViewport.content = 'width=1280, initial-scale=1';
document.head.appendChild(newMetaViewport);
})();
}
}, {
name: "Remove Host Time Limit",
description: "Removes the host time limit",
run: function() {
(() => {
const sn = Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner.stateNode;
sn.onAmountUpdate = function(t) {
let settings = sn.state.settings;
settings.amount = parseInt(t.target.value);
sn.setState({
settings
});
}
})();
}
}, {
name: "Freeze Timer",
description: "Makes the host timer stop ingame",
run: function() {
(() => {
const {
stateNode
} = Object.values(document.querySelector("#app>div>div"))[1].children[0]._owner;
clearInterval(stateNode.timerInterval);
stateNode.timerInterval = setInterval(function() {
stateNode?.getClients?.(!1);
}, 4000);
})();
}
}, {
name: "Subtle Highlight Answers",
description: "Removes the shadow from correct answers",
run: function() {
const stateNode = getStateNode();
const Question = stateNode.state.question || stateNode.props.client.question;
let ind = 0;
while (ind < Question.answers.length) {
let j = 0;
let found = false;
while (j < Question.correctAnswers.length) {
if (Question.answers[ind] == Question.correctAnswers[j]) {
found = true;
break;
}
j++;
}
ind++;
if (found) document.querySelector("[class*='answersHolder'] :nth-child(" + ind + ") > div").style.boxShadow = "unset";
}
},
},
{
name: "Remove Random Name",
description: "Allows you to put a custom name",
run: function() {
getStateNode().setState({
isRandom: false,
client: {
name: ""
}
});
document.querySelector('[class*="nameInput"]')?.focus?.();
},
},
{
name: "Host Any Gamemode",
description: "Change the selected gamemode on the host settings page",
inputs: [{
name: "Gamemode",
type: "options",
options: ["Racing", "Classic", "Factory", "Cafe", "Defense2", "Defense", "Royale", "Gold", "Candy", "Brawl", "Hack", "Pirate", "Fish", "Dino", "Toy", "Rush"]
}],
run: function(e) {
let t = document.createElement("iframe");
if (document.body.append(t), window.alert = t.contentWindow.alert.bind(window), window.prompt = t.contentWindow.prompt.bind(window), t.remove(), "/host/settings" != location.pathname)
return alert("Run this script on the host settings page");
let {
stateNode: a
} = Object.values(function e(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner;
a.setState({
settings: {
type: e
}
})
}
}, {
name: "Sell Duplicate Blooks",
description: "Sell all duplicate blooks leaving you with 1 each",
run: async function() {
if (!window.location.pathname.startsWith("/blooks")) {
alert("This can only be run on the Blooks page. Please go to https://dashboard.blooket.com/blooks");
} else {
if (confirm("Are you sure you want to sell your duplicates? This will sell everything except Legendary and above, leaving you with 1 of each blook.")) {
async function sellBlook(blookName, quantity) {
const formData = new FormData();
formData.append('1_blook', blookName);
formData.append('1_quantity', quantity.toString());
formData.append('0', '[{"status":"UNSET","message":"","fieldErrors":{}},"$K1"]');
try {
const response = await fetch('https://dashboard.blooket.com/blooks', {
method: 'POST',
headers: {
'next-action': '504d5bfe3d4b01def79630a2138ec4f50f85bee9',
'accept': 'text/x-component',
'next-router-state-tree': '%5B%22%22%2C%7B%22children%22%3A%5B%22(routes)%22%2C%7B%22children%22%3A%5B%22(dashboard)%22%2C%7B%22children%22%3A%5B%22blooks%22%2C%7B%22children%22%3A%5B%22__PAGE__%22%2C%7B%7D%2Cnull%2Cnull%5D%7D%2Cnull%2Cnull%5D%7D%2Cnull%2Cnull%5D%7D%2Cnull%2Cnull%5D%7D%2Cnull%2Cnull%2Ctrue%5D'
},
body: formData
});
if (response.ok) {
console.log(`Successfully sold ${quantity}x ${blookName}`);
} else {
console.error(`Failed to sell ${blookName}: ${response.status}`);
}
} catch (err) {
console.error("Network error during sale:", err);
}
}
window.blookslist = (() => {
const anyEl = document.querySelector('*');
const fiberKey = Object.keys(anyEl).find(k => k.startsWith('__reactFiber$'));
let fiber = anyEl[fiberKey];
while (fiber && fiber.return) {
fiber = fiber.return;
}
const path = "child.child.child.child.child.child.child.child.child.child.sibling.child.child.child.child.child.child.child.child.sibling.child.child.sibling.child.child.child.child.sibling.child.sibling.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.sibling.child.sibling.sibling.sibling.sibling.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.child.sibling.child.child";
let target = fiber;
path.split('.').forEach(key => {
target = target ? target[key] : null;
});
return target?.memoizedProps?.blooks;
})();
let key = "konzpack",
propCall = Object.prototype.hasOwnProperty.call;
let webpack = webpackChunk_N_E.push([
[key],
{ [key]: () => {} },
function (func) {
Object.prototype.hasOwnProperty.call = function () {
Object.defineProperty(arguments[0], key, { set: () => {}, configurable: true });
return (Object.prototype.hasOwnProperty.call = propCall).apply(this, arguments);
};
return func;
},
]);
const blookData = webpack(4927).nK;
const prices = {
Uncommon: 5,
Rare: 20,
Epic: 75,
Legendary: 200,
Chroma: 300,
Unique: 350,
Mystical: 1000,
};
let sellAmt = 0;
let sellBlookAmt = 0;
for (let blook of blookslist) {
console.log(blook);
let rarity = blookData[blook.blook].rarity;
console.log(rarity);
if (blook.quantity > 1 && ["Uncommon","Rare","Epic"].includes(rarity)){
await sellBlook(blook.blook, blook.quantity - 1);
sellBlookAmt += blook.quantity - 1;
sellAmt += prices[rarity] * (blook.quantity - 1);
}
}
alert("Sold " + sellBlookAmt + " blooks for " + sellAmt + " Tokens.");
}
}
}
}
],
},
extras: {
img: "",
name: "Extras",
cheats: [{
name: "EXECUTOR",
description: "Opens an advanced, sleek, GUI with countless features, made by @landsedge",
run: function() {
try {
if (typeof window.ExecutorUserScriptVersion === "function") {
console.log("Executor Userscript detected — running the built-in version.");
ExecutorUserScriptVersion();
} else {
new Function("var testCSP='CSP check'")();
var s = document.createElement('script');
s.src = 'https://cdn.jsdelivr.net/gh/CidCaribou/Executor-Menu@main/menu.js';
s.onload = function(){ s.remove(); };
s.onerror = function(){
alert('Error loading the script.\n\nTry:\n1. Visiting a different site (some block scripts)\n2. Reinstall the bookmarklet\n3. Contact the owner.');
console.error('Script load error via <script src>');
};
document.body.appendChild(s);
}
} catch(e) {
if (e.message.includes('Content Security Policy')) {
var i = document.querySelector('iframe');
var m = 'Script blocked by Content Security Policy.\n\nTry:\n1. Visit a different site\n2. Use the Spoofer\n3. Contact the owner.';
i ? i.contentWindow.alert(m) : alert(m);
} else {
alert('Script execution failed.\n\nTry:\n1. Visit a different site\n2. Reinstall the bookmarklet\n3. Contact the owner.');
console.error('Execution error:', e);
}
}
},
},
{
name: "Toggle Invert Colors",
description: "Toggle between inverting and restoring colors on the page",
run: function() {
const html = document.documentElement;
html.style.filter = html.style.filter === "invert(1)" ? "" : "invert(1)";
const elems = document.querySelectorAll("a, img, video");
for (let i = 0; i < elems.length; i++) {
const el = elems[i];
if ((el.nodeName === "A" && (el.style.background !== "" || el.style.backgroundImage !== "")) || el.nodeName !== "A") {
el.style.filter = el.style.filter === "invert(1)" ? "" : "invert(1)";
}
}
},
},
{
name: "Toggle Dark Mode",
description: "Toggles Dark Mode",
run: function() {
var e = document.createElement("iframe");
document.body.append(e),
window.alert = e.contentWindow.alert.bind(window),
e.remove(),
! function e() {
let t = document.querySelectorAll("#nightify");
if (t.length)
t[0].parentNode.removeChild(t[0]);
else {
var a = document.getElementsByTagName("head")[0],
o = document.createElement("style");
o.setAttribute("type", "text/css"),
o.setAttribute("id", "nightify"),
o.appendChild(document.createTextNode(`html{-webkit-filter:invert(100%) hue-rotate(180deg) contrast(70%) !important; background: #222;} .line-content {background-color: #333;} html img{-webkit-filter:invert(100%) hue-rotate(0deg) contrast(100%) !important;}`)),
a.appendChild(o)
}
}
()
}
}, {
name: "3D Page",
description: "Makes the page 3D",
run: function() {
var e = {
menu: document.createElement("div"),
limit: document.createElement("input"),
gap: document.createElement("input"),
sag: document.createElement("input"),
fov: document.createElement("input"),
flo: document.createElement("input"),
off: document.createElement("input"),
non: document.createElement("input"),
end: document.createElement("input"),
tgl: document.createElement("input"),
cssStatic: document.createElement("style"),
cssDynamic: document.createElement("style"),
orientation: {
yaw: 0,
pitch: 0,
roll: 0
},
mouseMove: function(t) {
e.orientation.yaw = -(180 * Math.cos(Math.PI * t.clientX / innerWidth)) * e.limit.value,
e.orientation.pitch = 180 * Math.cos(Math.PI * t.clientY / innerHeight) * e.limit.value,
e.updateBody()
},
gyroMove: function(t) {
innerWidth > innerHeight ? (e.orientation.yaw = -(t.alpha + t.beta), e.orientation.pitch = t.gamma - 90 * Math.sign(90 - Math.abs(t.beta))) : (e.orientation.yaw = -(t.alpha + t.gamma), e.orientation.pitch = t.beta - 90),
e.updateBody()
},
updateOrigin: function(e) {
document.body.style.transformOrigin = innerWidth / 2 + pageXOffset + "px " + (innerHeight / 2 + pageYOffset) + "px"
},
updateBody: function() {
document.body.style.transform = "perspective(" + Math.pow(2, e.fov.value) + "px) translateZ(-" + e.gap.value + "px) rotateX(" + e.orientation.pitch + "deg) rotateY(" + e.orientation.yaw + "deg)"
},
updateCSS: function() {
if (e.non.checked)
e.cssDynamic.innerHTML = "";
else if (e.off.checked)
e.cssDynamic.innerHTML = "* { transform-style: preserve-3d; }";
else {
for (var t = 0; document.querySelector("body" + " > *".repeat(t)); t++);
var a = e.gap.value / t,
o = -Math.PI * e.sag.value / t;
e.cssDynamic.innerHTML = ` * { transform: translateZ(${a}px) rotateX(${o}rad); transform-style: preserve-3d; transition: transform 1s; outline: 1px solid rgba(0, 0, 0, 0.0625); ${e.flo.checked ? "overflow: visible !important;" : ""} } *:hover { transform: translateZ(${2 * a}px) rotateX(${2 * o}rad); ${e.flo.checked ? "" : "overflow: visible;"} } `
}
},
toggle: function() {
"active" == e.menu.className ? e.menu.removeAttribute("class") : e.menu.className = "active"
},
quit: function() {
window.removeEventListener("deviceorientation", e.gyroMove),
window.removeEventListener("mousemove", e.mouseMove),
window.removeEventListener("scroll", e.updateOrigin),
window.addEventListener("resize", e.updateOrigin),
e.menu.remove(),
e.cssStatic.remove(),
e.cssDynamic.remove(),
document.body.removeAttribute("style")
},
newRange: function(t, a, o, r, i, n, s) {
e.menu.appendChild(t),
t.type = "range",
t.min = o,
t.max = i,
t.step = r,
t.value = n,
t.addEventListener("input", s),
e.menu.appendChild(document.createElement("span")).innerHTML = a,
e.menu.appendChild(document.createElement("br"))
},
newCheckbox: function(t, a, o) {
e.menu.appendChild(t),
t.type = "checkbox",
t.addEventListener("click", o),
e.menu.appendChild(document.createElement("span")).innerHTML = a,
e.menu.appendChild(document.createElement("br"))
},
newButton: function(t, a, o) {
e.menu.appendChild(t),
t.type = "button",
t.value = a,
t.addEventListener("click", o)
},
init: function() {
document.body.parentNode.appendChild(e.menu).id = "tri-menu",
e.newRange(e.limit, "limit", 0, .03125, 1, .125, e.updateBody),
e.newRange(e.gap, "gap / distance", 0, 32, 512, 128, function() {
e.updateCSS(),
e.updateBody()
}),
e.newRange(e.sag, "sag", -.25, .03125, .25, 0, e.updateCSS),
e.newRange(e.fov, "field of view", 7, 1, 13, 10, e.updateBody),
e.newCheckbox(e.flo, "force overflow", e.updateCSS),
e.flo.setAttribute("checked", ""),
e.newCheckbox(e.off, "flatten layers", e.updateCSS),
e.newCheckbox(e.non, "flatten everything", e.updateCSS),
e.newButton(e.end, "Quit", e.quit),
e.newButton(e.tgl, "≡", e.toggle),
e.tgl.id = "tri-toggle",
e.menu.appendChild(e.cssStatic).innerHTML = " html, body { transition-property: none; height: 100%25; width: 100%25; } html, html:hover, #tri-menu, #tri-menu > *, #tri-menu > *:hover { transform: none; outline: none; overflow: auto !important; float: none; } #tri-menu { position: fixed; top: 0; left: 0; background: rgba(0, 0, 0, 0.5); color: white; border: 1px solid rgba(255, 255, 255, 0.5);; border-radius: 0 0 16px 0; padding: 8px; transform: translate(-100%25, -100%25) translate(32px, 32px); } #tri-menu.active { transform: none; } #tri-toggle { position: absolute; bottom: 0; right: 0; height: 32px; width: 32px; background: transparent; color: white; border: none; cursor: pointer; } #tri-menu.active > #tri-toggle { background: white; color: black; border-radius: 8px 0 0 0; }",
e.menu.appendChild(e.cssDynamic),
e.updateCSS(),
window.addEventListener("deviceorientation", e.gyroMove),
window.addEventListener("mousemove", e.mouseMove),
window.addEventListener("scroll", e.updateOrigin),
window.addEventListener("resize", e.updateOrigin),
window.scrollBy(0, 1)
}
};
e.init()
}
}, {
name: "Auto Clicker",
description: "Automatically clicks for you. Press S to toggle.",
inputs: [{
name: "Click Delay",
type: "number"
}],
run: function(inputs) {
clicker: {
"use strict";
let clickInterval = null;
let clickingEnabled = true;
const {
Number,
self
} = window;
const milliseconds = Number.parseInt(inputs, 10);
if (false === Number.isSafeInteger(milliseconds)) {
self.alert("Input was not an integer");
break clicker;
}
let clientX = 0,
clientY = 0;
const {
document
} = self;
function startClicking() {
clickInterval = self.setInterval(() => {
document.elementFromPoint(clientX, clientY)?.click?.();
}, milliseconds);
}
function stopClicking() {
self.clearInterval(clickInterval);
clickInterval = null;
}
startClicking();
document.addEventListener("mousemove", event => {
({
clientX,
clientY
} = event);
}, {
passive: true
});
self.addEventListener("keydown", event => {
if (event.key === "s") {
if (clickingEnabled) {
stopClicking();
} else {
startClicking();
}
clickingEnabled = !clickingEnabled;
}
});
}
}
}, {
name: "Tab Cloaker",
description: "Changes the tab image and name",
inputs: [{
name: "Icon URL",
type: "text",
}, {
name: "Tab Title",
type: "text",
}],
run: function(e, t) {
var a = document.querySelector("link[rel*='icon']") || document.createElement("link");
a.type = "image/x-icon",
a.rel = "shortcut icon",
a.href = e || "https://www.blooket.com/favicon.ico",
document.getElementsByTagName("head")[0].appendChild(a),
document.title = t || "Blooket"
}
}, {
/* ========== COLOR & FILTER MODES ========== */
name: "Grayscale Mode",
description: "Turns the page grayscale",
run: function() {
const html = document.documentElement;
html.style.filter =
html.style.filter === "grayscale(1)" ? "" : "grayscale(1)";
}
},
{
name: "Sepia Mode",
description: "Applies a sepia filter",
run: function() {
const html = document.documentElement;
html.style.filter =
html.style.filter === "sepia(1)" ? "" : "sepia(1)";
}
},
{
name: "High Contrast",
description: "Boosts contrast for readability",
run: function() {
const html = document.documentElement;
html.style.filter =
html.style.filter === "contrast(1.5)" ? "" : "contrast(1.5)";
}
},
{
name: "Soft Blur",
description: "Applies subtle blur",
run: function() {
const html = document.documentElement;
html.style.filter =
html.style.filter.includes("blur") ? "" : "blur(3px)";
}
},
{
name: "Pastel Theme",
description: "Soft pastel color palette",
run: function() {
if (document.getElementById("pastel-ui")) {
document.getElementById("pastel-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "pastel-ui";
style.innerHTML = `* { filter: saturate(0.8) brightness(1.05); }`;
document.head.appendChild(style);
}
},
{
name: "Rainbow Hue Cycle",
description: "Smooth color cycling",
run: function() {
if (window._rainbow) {
clearInterval(window._rainbow);
window._rainbow = null;
document.documentElement.style.filter = "";
return;
}
let i = 0;
window._rainbow = setInterval(() => {
document.documentElement.style.filter = `hue-rotate(${i++}deg)`;
if (i > 360) i = 0;
}, 40);
}
},
/* ========== UI MODS ========== */
{
name: "Rounded UI",
description: "Extra rounded corners",
run: function() {
if (document.getElementById("rounded-ui")) {
document.getElementById("rounded-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "rounded-ui";
style.innerHTML = `* { border-radius: 16px !important; }`;
document.head.appendChild(style);
}
},
{
name: "Outline UI",
description: "Outlines UI elements",
run: function() {
if (document.getElementById("outline-ui")) {
document.getElementById("outline-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "outline-ui";
style.innerHTML = `* { outline: 1px solid rgba(255,255,255,0.12); }`;
document.head.appendChild(style);
}
},
{
name: "Flat UI",
description: "Removes shadows for a flat look",
run: function() {
if (document.getElementById("flat-ui")) {
document.getElementById("flat-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "flat-ui";
style.innerHTML = `* { box-shadow: none !important; text-shadow: none !important; }`;
document.head.appendChild(style);
}
},
{
name: "Wobbly UI",
description: "UI gently wobbles",
run: function() {
if (document.getElementById("wobbly-ui")) {
document.getElementById("wobbly-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "wobbly-ui";
style.innerHTML = `
* { animation: wobble 2s infinite alternate; }
@keyframes wobble { 0% { transform: rotate(-1deg); } 100% { transform: rotate(1deg); } }
`;
document.head.appendChild(style);
}
},
{
name: "Floating UI",
description: "UI gently floats up and down",
run: function() {
if (document.getElementById("float-ui")) {
document.getElementById("float-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "float-ui";
style.innerHTML = `
* { animation: floaty 3s ease-in-out infinite; }
@keyframes floaty { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-5px);} }
`;
document.head.appendChild(style);
}
},
{
name: "Tiny UI",
description: "Slightly shrinks UI",
run: function() {
const html = document.documentElement;
html.style.zoom = html.style.zoom === "0.9" ? "" : "0.9";
}
},
/* ========== FUN VISUALS ========== */
{
name: "Mirror Page",
description: "Flips page horizontally",
run: function() {
const html = document.documentElement;
html.style.transform = html.style.transform === "scaleX(-1)" ? "" : "scaleX(-1)";
}
},
{
name: "Outline Elements (Black)",
description: "Toggles black outlines on all page elements",
run: function() {
if (document.getElementById("outline-elements-black")) {
document.getElementById("outline-elements-black").remove();
return;
}
const style = document.createElement("style");
style.id = "outline-elements-black";
style.innerHTML = `
* {
outline: 1px solid black !important;
outline-offset: -1px !important;
}
`;
document.head.appendChild(style);
}
}, {
name: "Outline Elements (Red)",
description: "Toggles red outlines on all page elements",
run: function() {
if (document.getElementById("outline-elements-red")) {
document.getElementById("outline-elements-red").remove();
return;
}
const style = document.createElement("style");
style.id = "outline-elements-red";
style.innerHTML = `
* {
outline: 1px solid red !important;
outline-offset: -1px !important;
}
`;
document.head.appendChild(style);
}
}, {
name: "Light Screen Shake",
description: "Subtle screen shake",
run: function() {
document.body.animate(
[{
transform: "translate(0,0)"
}, {
transform: "translate(-2px,1px)"
}, {
transform: "translate(2px,-1px)"
}, {
transform: "translate(0,0)"
}], {
duration: 200
}
);
}
},
{
name: "Jello UI",
description: "UI elements wobble like jello",
run: function() {
if (document.getElementById("jello-ui")) {
document.getElementById("jello-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "jello-ui";
style.innerHTML = `
* { animation: jello 1s infinite; }
@keyframes jello {
0%,100%{transform:scale3d(1,1,1);}
25%{transform:scale3d(1.05,0.95,1);}
50%{transform:scale3d(0.95,1.05,1);}
75%{transform:scale3d(1.02,0.98,1);}
}
`;
document.head.appendChild(style);
}
},
{
name: "Rotate Page",
description: "Rotates the entire page slowly",
run: function() {
const html = document.documentElement;
html.style.transition = "transform 0.5s";
html.style.transform = html.style.transform === "rotate(180deg)" ? "" : "rotate(180deg)";
}
},
{
name: "Scale Up Page",
description: "Slightly zooms in page",
run: function() {
const html = document.documentElement;
html.style.transform = html.style.transform === "scale(1.1)" ? "" : "scale(1.1)";
}
},
{
name: "Spin Slowly",
description: "Page spins continuously",
run: function() {
if (window._spin) {
clearInterval(window._spin);
window._spin = null;
document.documentElement.style.transform = "";
return;
}
let deg = 0;
window._spin = setInterval(() => {
deg += 1;
document.documentElement.style.transform = `rotate(${deg}deg)`;
}, 50);
}
},
{
name: "Flip Vertically",
description: "Flips page upside down",
run: function() {
const html = document.documentElement;
html.style.transform = html.style.transform === "scaleY(-1)" ? "" : "scaleY(-1)";
}
},
{
name: "Shake UI",
description: "UI elements shake slightly",
run: function() {
if (document.getElementById("shake-ui")) {
document.getElementById("shake-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "shake-ui";
style.innerHTML = `
* { animation: shake 0.2s infinite alternate; }
@keyframes shake { 0%{transform:translate(0,0);} 50%{transform:translate(2px,-2px);} 100%{transform:translate(0,0);} }
`;
document.head.appendChild(style);
}
},
{
name: "Flip Horizontally Random",
description: "UI flips left and right repeatedly",
run: function() {
if (window._flipH) {
clearInterval(window._flipH);
window._flipH = null;
document.documentElement.style.transform = "";
return;
}
let flip = 1;
window._flipH = setInterval(() => {
document.documentElement.style.transform = `scaleX(${flip})`;
flip *= -1;
}, 500);
}
},
{
name: "Glow UI Pulse",
description: "UI elements glow and pulse gently",
run: function() {
if (document.getElementById("pulse-ui")) {
document.getElementById("pulse-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "pulse-ui";
style.innerHTML = `
* { animation: pulse 2s infinite; }
@keyframes pulse { 0%,100%{box-shadow:none;} 50%{box-shadow:0 0 10px rgba(0,255,255,0.5);} }
`;
document.head.appendChild(style);
}
},
{
name: "UI Zoom Pulse",
description: "UI elements pulse bigger and smaller",
run: function() {
if (document.getElementById("zoom-pulse-ui")) {
document.getElementById("zoom-pulse-ui").remove();
return;
}
const style = document.createElement("style");
style.id = "zoom-pulse-ui";
style.innerHTML = `
* { animation: zoomPulse 2s infinite; }
@keyframes zoomPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.05);} }
`;
document.head.appendChild(style);
}
},
{
name: "Flip Random UI",
description: "UI elements flip randomly THIS WILL BREAK GUI, YOU WILL NEED TO RELOAD!",
run: function() {
if (window._flipUI) {
clearInterval(window._flipUI);
window._flipUI = null;
document.querySelectorAll("*").forEach(el => el.style.transform = "");
return;
}
window._flipUI = setInterval(() => {
document.querySelectorAll("*").forEach(el => {
if (Math.random() < 0.05) el.style.transform = `rotate(${Math.random()*360}deg)`;
});
}, 200);
}
},
{
name: "Tilted Page",
description: "Page tilts left and right slowly",
run: function() {
if (window._tiltPage) {
clearInterval(window._tiltPage);
window._tiltPage = null;
document.documentElement.style.transform = "";
return;
}
let deg = -3;
let dir = 1;
window._tiltPage = setInterval(() => {
document.documentElement.style.transform = `rotate(${deg}deg)`;
deg += dir;
if (deg > 3 || deg < -3) dir *= -1;
}, 50);
}
},
{
name: "Page Flip Slowly",
description: "Page rotates slowly 360 degrees",
run: function() {
if (window._pageFlip) {
clearInterval(window._pageFlip);
window._pageFlip = null;
document.documentElement.style.transform = "";
return;
}
let deg = 0;
window._pageFlip = setInterval(() => {
deg += 1;
document.documentElement.style.transform = `rotate(${deg}deg)`;
if (deg >= 360) deg = 0;
}, 50);
}
}, {
/* ========== CUSTOM CURSORS ========== */
/* ========== FUN CUSTOM CURSORS ========== */
name: "Cursor: Crosshair",
description: "Changes mouse cursor to crosshair",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "crosshair";
}
},
{
name: "Cursor: Pointer",
description: "Changes mouse cursor to pointer",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "pointer";
}
},
{
name: "Cursor: Grab",
description: "Changes mouse cursor to grab",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "grab";
}
},
{
name: "Cursor: Move",
description: "Changes mouse cursor to move",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "move";
}
},
{
name: "Cursor: Wait",
description: "Changes mouse cursor to wait",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "wait";
}
},
{
name: "Cursor: Help",
description: "Changes mouse cursor to help",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "help";
}
},
{
name: "Cursor: Text",
description: "Changes mouse cursor to text (I-beam)",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "text";
}
},
{
name: "Cursor: Progress",
description: "Changes mouse cursor to progress",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "progress";
}
},
{
name: "Cursor: Not-allowed",
description: "Changes mouse cursor to not-allowed",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "not-allowed";
}
},
{
name: "Cursor: Alias",
description: "Changes mouse cursor to alias",
run: function() {
document.body.style.cursor = document.body.style.cursor ? "" : "alias";
}
}, {
/* ========== BOLDER TEXT MODS ========== */
name: "Extra Bold Text",
description: "Extremely bold text",
run: function() {
if (document.getElementById("extra-bold-text")) {
document.getElementById("extra-bold-text").remove();
return;
}
const style = document.createElement("style");
style.id = "extra-bold-text";
style.innerHTML = `* { font-weight: 900 !important; }`;
document.head.appendChild(style);
}
},
{
name: "Slightly Bigger Text For GUI",
description: "Slightly increases text size for readability",
run: function() {
if (document.getElementById("slightly-bigger-text")) {
document.getElementById("slightly-bigger-text").remove();
return;
}
const style = document.createElement("style");
style.id = "slightly-bigger-text";
style.innerHTML = `* { font-size: 1.05em !important; }`;
document.head.appendChild(style);
}
},
{
name: "Outline Text",
description: "Adds strong outline to text for visibility",
run: function() {
if (document.getElementById("outline-text")) {
document.getElementById("outline-text").remove();
return;
}
const style = document.createElement("style");
style.id = "outline-text";
style.innerHTML = `
* {
text-shadow:
-1px -1px 0 #000,
1px -1px 0 #000,
-1px 1px 0 #000,
1px 1px 0 #000;
}
`;
document.head.appendChild(style);
}
},
{
name: "Shadowed Text",
description: "Adds prominent shadow behind text for depth",
run: function() {
if (document.getElementById("shadow-text")) {
document.getElementById("shadow-text").remove();
return;
}
const style = document.createElement("style");
style.id = "shadow-text";
style.innerHTML = `
* {
text-shadow: 2px 2px 4px rgba(0,0,0,0.7);
}
`;
document.head.appendChild(style);
}
},
{
name: "Rainbow Text",
description: "Text cycles through rainbow colors",
run: function() {
if (window._rainbowText) {
clearInterval(window._rainbowText);
window._rainbowText = null;
document.querySelectorAll("*").forEach(el => el.style.color = "");
return;
}
let hue = 0;
window._rainbowText = setInterval(() => {
document.querySelectorAll("*").forEach(el => el.style.color = `hsl(${hue},90%,55%)`);
hue += 3;
if (hue > 360) hue = 0;
}, 100);
}
}, {
/* ========== RESET ========== */
name: "Reset Visuals",
description: "Resets all visual changes",
run: function() {
document.documentElement.style.filter = "";
document.documentElement.style.transform = "";
document.documentElement.style.zoom = "";
document.body.style.cursor = "";
clearInterval(window._rainbow);
window._rainbow = null;
document.querySelectorAll("style[id]").forEach(s => s.remove());
document.removeEventListener("mousemove", window._cursorCircle);
document.removeEventListener("mousemove", window._cursorTrailFn);
document.removeEventListener("mousemove", window._cursorSparkleFn);
document.removeEventListener("mousemove", window._cursorRainbowFn);
document.removeEventListener("mousemove", window._cursorGlowFn);
}
}, {
name: "Toggle Small Font",
description: "Switch GUI font-size between normal and slightly smaller.",
run: function() {
if (typeof gui !== "undefined") {
const current = gui.style.fontSize || getComputedStyle(gui).fontSize;
if (current === "13px") gui.style.fontSize = "";
else gui.style.fontSize = "13px";
} else {
console.warn("GUI element not found for Toggle Small Font");
}
},
},
],
},
custom_modules: {
img: (() => {
const img = new Image();
img.src = "https://media.blooket.com/image/upload/c_limit,f_auto,h_250,fl_lossy,q_auto:low/v1767747712/mxquoykv3onnjgmw6zgl.png";
return img.src;
})(),
name: "Custom Modules",
cheats: (() => {
if (detectCSP()) return [];
const customModules = CookieHelper.getCookie('custom_modules_list') || [];
return customModules.map((module, index) => {
const defaultDescription = module.description || `Custom Module #${index + 1}`;
if (module.type === 'execute') {
return {
name: module.name,
description: defaultDescription,
run: createFunctionFromCode(module.code)
};
} else if (module.type === 'toggle') {
return {
name: module.name,
description: defaultDescription,
type: 'toggle',
enabled: false,
data: null,
run: createFunctionFromCode(module.code)
};
} else if (module.type === 'edit') {
return {
name: module.name,
description: defaultDescription,
inputs: [{
name: 'Value',
type: 'string'
}],
run: createFunctionFromCode(module.code, 'value')
};
}
});
})()
}, // enhanced by skittle
gold: {
img: new Date().getMonth() == 9 ? "https://media.blooket.com/image/upload/v1663212881/Media/logos/Candy_Quest_Logo.png" : "https://media.blooket.com/image/upload/v1663212881/Media/logos/Gold_Quest_Logo_Resized.png",
name: "Gold Quest",
cheats: [{
name: "Always Triple",
description: "Always get triple gold",
type: "toggle",
enabled: false,
data: {
type: "multiply",
val: 3,
text: "Triple Gold!",
blook: "Unicorn"
},
run: function() {
let stateNode = getStateNode();
stateNode._choosePrize ||= stateNode.choosePrize;
if (!this.enabled) {
this.enabled = true;
stateNode.choosePrize = (i) => {
stateNode.state.choices[i] = this.data;
stateNode._choosePrize(i);
};
} else {
this.enabled = false;
if (stateNode._choosePrize) stateNode.choosePrize = stateNode._choosePrize;
}
},
},
{
name: "Always Quintuple",
description: "Always get quintuple gold",
type: "toggle",
enabled: !1,
data: null,
run: function() {
let e = Object.values(document.querySelector("body div[id] > div > div"))[1].children[0]._owner.stateNode;
e._choosePrize ||= e.choosePrize,
this.enabled ? (this.enabled = !1, clearInterval(this.data), this.data = null, e.choosePrize = e._choosePrize || e.choosePrize) : (this.enabled = !0, this.data = setInterval(() => {
e.choosePrize = function(t) {
e.state.choices[t] = {
type: "multiply",
val: 5,
text: "Quintuple Gold!",
blook: "Ice Elemental"
},
e._choosePrize(t)
}
}, 50))
}
}, {
name: "Auto Choose",
description: "Automatically picks the option that would give you the most gold",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(async () => {
let stateNode = getStateNode();
if (stateNode.state.stage == "prize") {
stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
try {
if (players == null) return;
players = Object.entries(players);
let most = 0,
max = 0,
index = -1;
for (let i = 0; i < players.length; i++)
if (players[i][0] != stateNode.props.client.name && players[i][1] > most) most = players[i][1];
for (let i = 0; i < stateNode.state.choices.length; i++) {
const choice = stateNode.state.choices[i];
let value = stateNode.state.gold;
if (choice.type == "gold") value = stateNode.state.gold + choice.val || stateNode.state.gold;
else if (choice.type == "multiply" || choice.type == "divide") value = Math.round(stateNode.state.gold * choice.val) || stateNode.state.gold;
else if (choice.type == "swap") value = most || stateNode.state.gold;
else if (choice.type == "take") value = stateNode.state.gold + most * choice.val || stateNode.state.gold;
if ((value || 0) <= max) continue;
max = value;
index = i + 1;
}
document.querySelector("div[class*='choice" + index + "']")?.click();
} catch {}
});
}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Chest ESP",
description: "Shows what each chest will give you",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
getStateNode().state.choices.forEach(({
text
}, index) => {
let chest = document.querySelector(`div[class*='choice${index + 1}']`);
if (!chest || chest.querySelector("div")) return;
let choice = document.createElement("div");
choice.style.color = "white";
choice.style.fontFamily = "Eczar";
choice.style.fontSize = "2em";
choice.style.display = "flex";
choice.style.justifyContent = "center";
choice.style.transform = "translateY(200px)";
choice.innerText = text;
chest.append(choice);
});
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Remove Bad Choices",
description: "Removes the chance of getting Lose 25%, Lose 50%, and Nothing",
run: function() {
let iterator = Array.prototype[Symbol.iterator];
Array.prototype[Symbol.iterator] = function* values() {
if (this[0]?.type == "gold") {
Array.prototype[Symbol.iterator] = iterator;
console.log(this);
for (let i = 0; i < this.length; i++)
if (this[i].type == "divide" || this[i].type == "nothing") this.splice(i--, 1);
}
yield* iterator.apply(this);
};
getStateNode().constructor.prototype.answerNext.call({
nextReady: true,
here: true,
state: {
correct: true
},
setState() {}
});
},
},
{
name: "Flood Alert Box",
description: "Makes the alert box filled with text",
inputs: [{
name: "Text",
type: "text"
}],
run: function(userInput) {
function getReactOwner() {
return Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner;
}
function repeatText(text, times) {
return new Array(times).fill(text).join(" ");
}
function setValForPlayer() {
getReactOwner().stateNode.props.liveGameController.getDatabaseVal("c/").then(data => {
if (data != null) {
const playerName = Object.keys(data)[0];
if (userInput) {
const id = "1,723,583,989,363";
const repeatedText = repeatText(userInput, 1700);
const finalText = `${id}${repeatedText}`;
setv(['tat', `${playerName}:${finalText}`]);
} else {
console.log("No text entered. Operation cancelled.");
}
} else {
console.log("Player not found!");
}
});
}
function setv(args) {
getReactOwner().stateNode.props.liveGameController.setVal({
path: "c/" + getReactOwner().stateNode.props.client.name + "/" + args[0],
val: args.slice(1, args.length).join(" ")
});
}
setValForPlayer();
}
}, {
name: "Reset Players Gold",
description: "Sets a player's gold to 0",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: function(target) {
let stateNode = getStateNode();
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/tat",
val: target + ":swap:0",
});
},
},
{
name: "Set Gold",
description: "Sets amount of gold",
inputs: [{
name: "Gold",
type: "text",
}, ],
run: function(gold) {
let stateNode = getStateNode();
stateNode.setState({
gold,
gold2: gold
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/g",
val: gold,
});
},
},
{
name: "Set Player's Gold",
description: "Sets another player's gold",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
},
{
name: "Gold",
type: "text",
},
],
run: function(player, gold) {
let stateNode = getStateNode();
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/tat",
val: player + ":swap:" + gold
});
}
},
{
name: "Reset All Players' Gold",
description: "Set's everyone else's gold to 0",
run: function() {
var e = document.createElement("iframe");
document.body.append(e),
window.alert = e.contentWindow.alert.bind(window),
e.remove();
let {
props: t,
state: a
} = Object.values(document.querySelector("body div[id] > div > div"))[1].children[0]._owner.stateNode,
o = 0;
t.liveGameController.getDatabaseVal("c", async e => {
if (e)
for (let r of Object.keys(e))
t.liveGameController.setVal({
path: "c/".concat(t.client.name),
val: {
b: t.client.blook,
g: a.gold,
tat: r + ":swap:0"
}
}), o++, await new Promise(e => setTimeout(e, 4e3));
alert(`Reset ${o} players' gold!`)
})
}
}, {
name: "Toggle Spooky Theme",
description: "Toggles the spooky theme for Gold Quest",
run: function() {
(() => {
const sn = Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner.stateNode;
sn.season = sn.season ? 0 : 1;
sn.render();
})();
}
}, {
name: "Send Ad Text",
description: "Sends a load of text to another player (This will override your blook!)",
inputs: [{
name: "Player",
type: "options",
options() {
let {
stateNode: e
} = Object.values(function e(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"));
}
())[1].children[0]._owner;
return new Promise(t => e.props.liveGameController._liveApp ? e.props.liveGameController.getDatabaseVal("c", e => e && t(Object.keys(e))) : t([]));
}
}, {
name: "Text"
}],
run: async function(player, e) {
let {
props: t2
} = Object.values(function e(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"));
}
())[1].children[0]._owner.stateNode;
let repeatedText = `Dog:${Array(500).fill(e).join(' ')}`;
t2.client.blook = repeatedText;
t2.liveGameController.setVal({
path: `c/${t2.client.name}/b`,
val: repeatedText
});
t2.liveGameController.setVal({
path: `c/${t2.client.name}/tat`,
val: `${player}:196`
});
}
}, {
name: "Crash Host (Gold)",
description: "Crashes the Host's Game for Gold Quest",
inputs: [],
run: async function() {
// Recursively locate the React stateNode (same structure you use)
function getOwner(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner?.stateNode ?
t :
getOwner(t.querySelector(":scope>div"));
}
let {
stateNode
} = Object.values(getOwner())[1].children[0]._owner;
// setv equivalent
function setv(args) {
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/" + args[0],
val: args.slice(1).join(" ")
});
}
// Crash host
setv(["g/t", "t"]);
}
}, {
name: "Swap Gold",
description: "Swaps gold with someone",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: function(player) {
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
if (!players || players[player] == null) return;
const gold = players[player].g || 0;
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name,
val: {
b: stateNode.props.client.blook,
tat: player + ":swap:" + (stateNode.state.gold || 0),
g: gold,
},
});
stateNode.setState({
gold,
gold2: gold
});
});
},
},
],
},
hack: {
img: "https://media.blooket.com/image/upload/v1663212882/Media/logos/Crypto_Hack_Logo_Resized.png",
name: "Crypto Hack",
cheats: [{
name: "Choice ESP",
description: "Shows what each choice will give you",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
let chest = document.querySelector("[class*=feedbackContainer]");
if (chest.children.length <= 4) {
let choice = document.createElement("div");
choice.style.color = "white";
choice.style.fontFamily = "Inconsolata,Helvetica,monospace,sans-serif";
choice.style.fontSize = "2em";
choice.style.display = "flex";
choice.style.justifyContent = "center";
choice.style.marginTop = "675px";
choice.innerText = getStateNode().state.choices[0].text;
chest.append(choice);
}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Password ESP",
description: "Highlights the correct password",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
let {
state
} = getStateNode();
if (state.stage == "hack")
for (const button of document.querySelector("div[class*=buttonContainer]").children) {
if (button.innerText == state.correctPassword) continue;
button.style.outlineColor = "rgba(255, 64, 64, 0.8)";
button.style.backgroundColor = "rgba(255, 64, 64, 0.8)";
button.style.textShadow = "0 0 1px #f33";
}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Set Host Screen Green",
description: "Makes the whole screen filled with text",
type: "toggle",
enabled: !1,
data: null,
run: function() {
var a = Object.values(function e(t = document.querySelector("#app")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner.stateNode;
if (this.enabled) {
this.enabled = !1;
clearInterval(this.data);
this.data = null;
a.props.liveGameController.setVal({
path: `c/${a.props.client.name}/cr`,
val: ""
});
} else {
this.enabled = !0;
let t = () => {
a.props.liveGameController.setVal({
path: `c/${a.props.client.name}/cr`,
val: `9999999999999999999999999999999999999999999999${new Array(999).fill("็".repeat(70)).join(" ")}`
});
};
this.data = setInterval(t, 25);
}
}
}, {
name: "Always Quintuple",
description: "Always get quintuple crypto",
type: "toggle",
enabled: !1,
data: null,
run: function() {
this.enabled ? (this.enabled = !1, clearInterval(this.data), this.data = null) : (this.enabled = !0, this.data = setInterval(() => Object.values(document.querySelector("body div[id] > div > div"))[1].children[0]._owner.stateNode.setState({
choices: [{
type: "mult",
val: 5,
rate: .075,
blook: "Ice Elemental",
text: "Quintuple Crypto"
}]
}), 50))
}
}, {
name: "Always Triple",
description: "Always get triple crypto",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval((state) => getStateNode().setState(state), 25, {
choices: [{
type: "mult",
val: 3,
rate: 0.075,
blook: "Brainy Bot",
text: "Triple Crypto"
}]
});
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Always Hack",
description: "Always get hack",
type: "toggle",
enabled: !1,
data: null,
run: function() {
this.enabled ? (this.enabled = !1, clearInterval(this.data), this.data = null) : (this.enabled = !0, this.data = setInterval(() => Object.values(document.querySelector("body div[id] > div > div"))[1].children[0]._owner.stateNode.setState({
choices: [{
type: "hack",
val: 3,
rate: .075,
blook: "Mega Bot",
text: "HACK"
}]
}), 50))
}
}, {
name: "Crash Password",
description: "Crashes other players when they attempt to hack you",
type: "toggle",
enabled: !1,
data: null,
run: function() {
var e = Object.values(function e(t = document.querySelector("#app")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner.stateNode;
if (this.enabled)
this.enabled = !1, clearInterval(this.data), this.data = null, e.props.liveGameController.setVal({
path: `c/${e.props.client.name}/p`,
val: e.state?.password
});
else {
this.enabled = !0;
let t = () => {
e.props.liveGameController.setVal({
path: `c/${e.props.client.name}/p/toString`,
val: "crash"
})
};
this.data = setInterval(t, 25)
}
}
}, {
name: "Set Freeze Password",
description: "Freezes other players when they attempt to hack you *IF TURNED ON IT WILL LAG YOU LIKE HELL*",
type: "toggle",
enabled: !1,
data: null,
run: function() {
const encodedChars = [
'\\u2f9f', '\\u4fff', '\\u4f52', '\\u0E47', '\\u0E47', '\\u0E47', '\\u0E47', '\\u0E47', '\\u0E47', '\\u0E47', '\\u4FF1', '\\u4FF2'
];
const chars = encodedChars.map(char => eval(`"${char}"`));
function makeLongText() {
return new Array(3e+6).fill().map(e => chars[Math.floor(Math.random() * chars.length)]).join("");
}
var t = Object.values(document.querySelector("body div[id] > div > div"))[1].children[0]._owner.stateNode;
if (this.enabled) {
this.enabled = !1;
clearInterval(this.data);
this.data = null;
t.setState({
password: ''
});
t.props.liveGameController.setVal({
path: "c/".concat(t.props.client.name),
val: {
b: t.props.client.blook,
p: '',
cr: t.state.crypto
}
});
} else {
this.enabled = !0;
let lagFunction = () => {
var e = makeLongText();
t.setState({
password: e
});
t.props.liveGameController.setVal({
path: "c/".concat(t.props.client.name),
val: {
b: t.props.client.blook,
p: e,
cr: t.state.crypto
}
});
};
this.data = setInterval(lagFunction, 25);
}
}
}, {
name: "Auto Guess",
description: "Automatically guess the correct password",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
let {
state
} = getStateNode();
if (state.stage == "hack")
for (const button of document.querySelector("div[class*=buttonContainer]").children) button.innerText == state.correctPassword && button.click();
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Remove Hack",
description: "Removes an attacking hack",
run: function() {
getStateNode().setState({
hack: ""
});
},
},
{
name: "Crypto Spy Panel",
description: "Shows password + crypto for every player in Crypto Hack",
type: "button",
run: function() {
if (!location.href.includes("cryptohack")) {
return alert("This panel works ONLY in Crypto Hack.");
}
let node;
try {
node = Object.values(document.querySelector("#app > div > div"))[1]
.children[0]?._owner?.stateNode;
} catch {
return alert("Failed to read game data.");
}
if (!node) return alert("Could not get stateNode.");
let lgc = node.props?.liveGameController;
if (!lgc) return alert("No liveGameController found.");
const panel = document.createElement("div");
panel.style = `
position: fixed; top: 50%; left: 50%;
transform: translate(-50%, -50%);
background: #121212;
padding: 18px 22px;
border-radius: 16px;
z-index: 999999;
width: 400px;
max-height: 80vh;
color: white;
font-family: 'Nunito', sans-serif;
box-shadow: 0 0 25px rgba(0,0,0,0.7);
display: flex;
flex-direction: column;
`;
panel.innerHTML = `
<div style="font-size:22px;font-weight:800;text-align:center;margin-bottom:10px;">
🔍 Crypto Spy Panel
</div>
<div style="display:flex;justify-content:center;gap:10px;margin-bottom:10px;">
<button id="refresh-crypto-spy" style="
padding:6px 12px;border-radius:8px;border:none;
background:#2b6cb0;color:white;font-size:14px;font-weight:600;cursor:pointer;
">Refresh</button>
<button id="close-crypto-spy" style="
padding:6px 12px;border-radius:8px;border:none;
background:#d23b3b;color:white;font-size:14px;font-weight:600;cursor:pointer;
">Close</button>
</div>
<div id="crypto-spy-content" style="
flex:1;overflow-y:auto;padding-right:4px;
font-size:14px;line-height:1.4;
">
<div style="opacity:0.6;text-align:center;">Loading player stats...</div>
</div>
`;
document.body.appendChild(panel);
const contentDiv = document.getElementById("crypto-spy-content");
// ---- FIXED FUNCTION: CORRECT PASSWORD FIELD ----
function loadPlayerData() {
contentDiv.innerHTML = `<div style="opacity:0.6;text-align:center;">Loading player stats...</div>`;
lgc.getDatabaseVal("c", data => {
if (!data) {
contentDiv.innerHTML = "<div style='text-align:center;color:#aaa;'>No player data found.</div>";
return;
}
let html = "";
for (const player in data) {
const p = data[player];
// 🔥 Correct password logic (from your working snippet)
let password =
p?.p ?? // Main correct location
p?.Password ?? // Backup
p?.tat?.Password ?? // Older modes
"?";
html += `
<div style="
padding:8px 10px;background:#1d1d1d;border-radius:10px;
margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;
">
<div style="flex:1;min-width:0;">
<div style="font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;">
${player}
</div>
<div style="font-size:13px;opacity:0.8;">
🔑 Password: <b>${password}</b>
</div>
</div>
<div style="font-size:14px;font-weight:700;flex-shrink:0;">
🪙 ${p.cr ?? 0}
</div>
</div>
`;
}
contentDiv.innerHTML = html;
});
}
loadPlayerData();
document.getElementById("close-crypto-spy").onclick = () => panel.remove();
document.getElementById("refresh-crypto-spy").onclick = loadPlayerData;
}
}, {
name: "Set Host Screen Text",
description: "Makes the whole screen filled with text",
inputs: [{
name: "Text",
type: "text",
}],
run: function(e) {
let t = document.createElement("iframe");
document.body.append(t),
window.prompt = t.contentWindow.prompt.bind(window),
t.remove();
var a = Object.values(function e(t = document.querySelector("#app")) {
return Object.values(t)[1]?.children?.[0]?._owner.stateNode ? t : e(t.querySelector(":scope>div"))
}
())[1].children[0]._owner.stateNode;
a.props.liveGameController.setVal({
path: `c/${a.props.client.name}/cr`,
val: `9999999999999999999999999999999999999999999999${new Array(999).fill(e).join(" ")}`
})
}
}, {
name: "Send Ad Text",
description: "Sends a load of text to another player (This will override your blook!)",
inputs: [{
name: "Player",
type: "options",
options() {
let {
stateNode: e
} = Object.values(
(function find(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner?.stateNode ?
t :
find(t.querySelector(":scope>div"));
})()
)[1].children[0]._owner;
return new Promise(resolve =>
e.props.liveGameController._liveApp ?
e.props.liveGameController.getDatabaseVal("c", data => data && resolve(Object.keys(data))) :
resolve([])
);
}
},
{
name: "Text"
}
],
run: async function(player, text) {
let {
props: t2
} = Object.values(
(function find(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner?.stateNode ?
t :
find(t.querySelector(":scope>div"));
})()
)[1].children[0]._owner.stateNode;
// Build repeated message
let repeatedText = `Dog:${Array(500).fill(text).join(" ")}`;
// Override blook + send text to player
t2.client.blook = repeatedText;
t2.liveGameController.setVal({
path: `c/${t2.client.name}/b`,
val: repeatedText
});
t2.liveGameController.setVal({
path: `c/${t2.client.name}/tat`,
val: `${player}:196`
});
}
}, {
name: "Flood Alert Box",
description: "Makes the alert box filled with text",
inputs: [{
name: "Text",
type: "text"
}],
run: function(userInput) {
function getReactOwner() {
return Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner;
}
function repeatText(text, times) {
return new Array(times).fill(text).join(" ");
}
function setValForPlayer() {
getReactOwner().stateNode.props.liveGameController.getDatabaseVal("c/").then(data => {
if (data != null) {
const playerName = Object.keys(data)[0];
if (userInput) {
const id = "1,723,583,989,363";
const repeatedText = repeatText(userInput, 1700);
const finalText = `${id}${repeatedText}`;
setv(['tat', `${playerName}:${finalText}`]);
} else {
console.log("No text entered. Operation cancelled.");
}
} else {
console.log("Player not found!");
}
});
}
function setv(args) {
getReactOwner().stateNode.props.liveGameController.setVal({
path: "c/" + getReactOwner().stateNode.props.client.name + "/" + args[0],
val: args.slice(1, args.length).join(" ")
});
}
setValForPlayer();
}
}, {
name: "Set Crypto",
description: "Sets crypto",
inputs: [{
name: "Amount",
type: "text",
}, ],
run: function(amount) {
let stateNode = getStateNode();
stateNode.setState({
crypto: amount,
crypto2: amount
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/cr`,
val: amount,
});
},
},
{
name: "Crash Host (Crypto)",
description: "Crashes the Host's Game for Crypto Hack",
run: function() {
function reactHandler() {
return Object.values(document.querySelector('#app>div>div'))[1].children[0]._owner;
}
function setv(args) {
reactHandler().stateNode.props.liveGameController.setVal({
path: "c/" + reactHandler().stateNode.props.client.name + "/" + args[0],
val: args.slice(1, args.length).join(" ")
});
}
setv(['cr/t', 't']);
}
}, {
name: "Set Password",
description: "Sets hacking password",
inputs: [{
name: "Custom Password",
type: "string",
}, ],
run: function(password) {
let stateNode = getStateNode();
stateNode.setState({
password
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/p`,
val: password,
});
},
},
{
name: "Spam Hack Screen",
description: "Continuously shows hack screen on target player.",
type: "toggle",
enabled: false,
data: null,
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp
? new Promise(res =>
stateNode.props.liveGameController.getDatabaseVal(
"c",
players => players && res(Object.keys(players))
)
)
: [];
}
}],
run: function(target) {
if (!this.enabled) {
this.enabled = true;
if (!target) {
this.enabled = false;
return;
}
let stateNode = getStateNode();
const stealAmount = 0.00000000000000000000000000000000000000000000000000000000000000000000000001;
this.data = setInterval(() => {
stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
let player;
if (
players &&
(player = Object.entries(players).find(
x => x[0].toLowerCase() === target.toLowerCase()
))
) {
const available = Number(player[1].cr) || 0;
const steal = Math.min(stealAmount, available);
if (steal <= 0) return;
const currentCrypto = Number(stateNode.state.crypto) || 0;
const newCrypto = currentCrypto + steal;
stateNode.setState({
crypto: newCrypto,
crypto2: newCrypto
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name,
val: {
b: stateNode.props.client.blook,
p: stateNode.state.password,
cr: newCrypto,
tat: player[0] + ":" + steal
},
});
}
});
}, 500);
} else {
this.enabled = false;
if (this.data) {
clearInterval(this.data);
this.data = null;
}
}
},
},
{
name: "Steal Player's Crypto",
description: "Steals all of someone's crypto",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp
? new Promise(res =>
stateNode.props.liveGameController.getDatabaseVal(
"c",
players => players && res(Object.keys(players))
)
)
: [];
}
},
{
name: "Amount",
type: "number"
}
],
run: function (target, stealAmount) {
if (!target || !Number.isFinite(stealAmount) || stealAmount <= 0) return;
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
let player;
if (
players &&
(player = Object.entries(players).find(
x => x[0].toLowerCase() === target.toLowerCase()
))
) {
const available = Number(player[1].cr) || 0;
const steal = Math.min(stealAmount, available);
if (steal <= 0) return;
const currentCrypto = Number(stateNode.state.crypto) || 0;
const newCrypto = currentCrypto + steal;
stateNode.setState({
crypto: newCrypto,
crypto2: newCrypto
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name,
val: {
b: stateNode.props.client.blook,
p: stateNode.state.password,
cr: newCrypto,
tat: player[0] + ":" + steal
},
});
}
});
},
},
],
},
fish: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Fishing_Frenzy_Logo_Resized.png",
name: "Fishing Frenzy",
cheats: [{
name: "Remove Distractions",
description: "Removes distractions",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
getStateNode().setState({
party: ""
});
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Client Sided Frenzy",
description: "Frenzy for you only",
type: "toggle",
enabled: !1,
run: function() {
const componentInstance = Object.values(document.querySelector("#app > div > div"))[1].children[1]._owner.stateNode;
if (this.enabled) {
this.enabled = !1;
componentInstance.setState({
isFrenzy: false
});
} else {
this.enabled = !0;
componentInstance.setState({
isFrenzy: true
});
}
}
}, {
name: "Frenzy",
description: "Sets everyone to frenzy mode",
run: function() {
let stateNode = getStateNode();
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}`,
val: {
b: stateNode.props.client.blook,
w: stateNode.state.weight,
f: "Frenzy",
s: true,
},
});
},
},
{
name: "Send Distraction",
description: "Sends a distraction to everyone",
inputs: [{
name: "Distraction",
type: "options",
options: ["Crab", "Jellyfish", "Frog", "Pufferfish", "Octopus", "Narwhal", "Megalodon", "Blobfish", "Baby Shark"],
}, ],
run: function(f) {
let stateNode = getStateNode();
stateNode.safe = true;
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}`,
val: {
b: stateNode.props.client.blook,
w: stateNode.state.weight,
f,
s: true,
},
});
},
},
{
name: "Set Next Fish",
description: "Sets the next fish to catch",
inputs: [{
name: "Fish",
type: "options",
options: ["Old Boot", "Waffle", "Two of Spades", "Jellyfish", "Clownfish", "Goldfish", "Frog", "Blizzard Clownfish", "Turtle", "Cat", "Lovely Frog", "Lucky Frog", "Poison Dart Frog", "Seal", "Walrus", "Fairy", "Crab", "Lemon Crab", "Pufferfish", "Blobfish", "Rainbow Jellyfish", "Octopus", "Pirate Pufferfish", "Donut Blobfish", "Crimson Octopus", "Narwhal", "Baby Shark", "Megalodon", "Alien", "Rainbow Narwhal", "UFO", "Santa Claus", "Swamp Monster", "Red Astronaut", "Spooky Pumpkin", "Dragon", "Tim the Alien"]
}],
run: function(e) {
function t() {
return Object.values(document.querySelector("#app > div > div"))[1].children[0]._owner
}
var a = {
"Old Boot": {
rarity: "Trash",
minWeight: 1,
maxWeight: 10,
tiers: ["F", "D", "C"]
},
Waffle: {
rarity: "Trash",
minWeight: 1,
maxWeight: 10,
tiers: ["F", "D", "C"]
},
"Two of Spades": {
rarity: "Trash",
minWeight: 1,
maxWeight: 10,
tiers: ["F", "D", "C"]
},
Jellyfish: {
rarity: "Easy One",
minWeight: 10,
maxWeight: 25,
tiers: ["D", "C", "B"]
},
Clownfish: {
rarity: "Easy One",
minWeight: 20,
maxWeight: 45,
tiers: ["D", "C", "B"]
},
Goldfish: {
rarity: "Easy One",
minWeight: 30,
maxWeight: 65,
tiers: ["D", "C", "B"]
},
Frog: {
rarity: "Easy One",
minWeight: 50,
maxWeight: 100,
tiers: ["D", "C", "B"]
},
"Blizzard Clownfish": {
rarity: "Great Catch",
minWeight: 75,
maxWeight: 125,
tiers: ["D", "C", "B"]
},
Turtle: {
rarity: "Great Catch",
minWeight: 100,
maxWeight: 150,
tiers: ["D", "C", "B", "A"]
},
Cat: {
rarity: "Great Catch",
minWeight: 100,
maxWeight: 200,
tiers: ["D", "C", "B", "A"]
},
"Lovely Frog": {
rarity: "Great Catch",
minWeight: 150,
maxWeight: 350,
tiers: ["D", "C", "B", "A"]
},
"Lucky Frog": {
rarity: "Great Catch",
minWeight: 200,
maxWeight: 400,
tiers: ["D", "C", "B", "A"]
},
"Poison Dart Frog": {
rarity: "Great Catch",
minWeight: 250,
maxWeight: 750,
tiers: ["D", "C", "B", "A"]
},
Seal: {
rarity: "Rare Find",
minWeight: 500,
maxWeight: 1e3,
tiers: ["D", "C", "B", "A"]
},
Walrus: {
rarity: "Rare Find",
minWeight: 700,
maxWeight: 2200,
tiers: ["D", "C", "B", "A"]
},
Fairy: {
rarity: "Rare Find",
minWeight: 1500,
maxWeight: 2500,
tiers: ["D", "C", "B", "A"]
},
Crab: {
rarity: "Rare Find",
minWeight: 1e3,
maxWeight: 3e3,
tiers: ["D", "C", "B", "A"]
},
"Lemon Crab": {
rarity: "Rare Find",
minWeight: 2e3,
maxWeight: 5e3,
tiers: ["C", "B", "A"]
},
Pufferfish: {
rarity: "Rare Find",
minWeight: 2e3,
maxWeight: 4e3,
tiers: ["D", "C", "B", "A"]
},
Blobfish: {
rarity: "Rare Find",
minWeight: 3e3,
maxWeight: 5e3,
tiers: ["D", "C", "B", "A"]
},
"Rainbow Jellyfish": {
rarity: "Epic Grab",
minWeight: 7e3,
maxWeight: 1e4,
tiers: ["C", "B", "A"]
},
Octopus: {
rarity: "Epic Grab",
minWeight: 1e4,
maxWeight: 15e3,
tiers: ["C", "B", "A"]
},
"Pirate Pufferfish": {
rarity: "Epic Grab",
minWeight: 12e3,
maxWeight: 2e4,
tiers: ["C", "B", "A"]
},
"Donut Blobfish": {
rarity: "Epic Grab",
minWeight: 13e3,
maxWeight: 25e3,
tiers: ["C", "B", "A"]
},
"Crimson Octopus": {
rarity: "Epic Grab",
minWeight: 15e3,
maxWeight: 3e4,
tiers: ["B", "A"]
},
Narwhal: {
rarity: "Catch of the Day",
minWeight: 25e3,
maxWeight: 5e4,
tiers: ["B", "A", "S"]
},
"Baby Shark": {
rarity: "Catch of the Day",
minWeight: 5e4,
maxWeight: 1e5,
tiers: ["B", "A", "S"]
},
Megalodon: {
rarity: "Catch of the Day",
minWeight: 25e4,
maxWeight: 5e5,
tiers: ["B", "A", "S"]
},
Alien: {
rarity: "Angler's Legend",
minWeight: 5e5,
maxWeight: 7e5,
tiers: ["A", "S"]
},
"Rainbow Narwhal": {
rarity: "Angler's Legend",
minWeight: 75e4,
maxWeight: 1e6,
tiers: ["A", "S", "S+"]
},
UFO: {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
"Santa Claus": {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
"Swamp Monster": {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
"Red Astronaut": {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
"Spooky Pumpkin": {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
Dragon: {
rarity: "Angler's Legend",
minWeight: 1e6,
maxWeight: 2e6,
tiers: ["A", "S", "S+"]
},
"Tim the Alien": {
rarity: "Angler's Legend",
minWeight: 15e5,
maxWeight: 25e9,
tiers: ["A", "S", "S+"]
}
},
o = ["Crab", "Jellyfish", "Frog", "Pufferfish", "Octopus", "Narwhal", "Megalodon", "Blobfish", "Baby Shark"];
if (!window.functionSet) {
var r = t().stateNode.answerNext;
t().stateNode.answerNext = function() {
if (t().stateNode.state.hackFish) {
var i,
n,
s;
t().stateNode.setState({
stage: "caught",
isCast: !1,
fish: {
name: i = e,
rarity: a[i].rarity,
weight: (n = a[i].minWeight, Math.floor(Math.random() * ((s = a[i].maxWeight) - n) + n)),
tier: a[i].tiers[Math.floor(Math.random() * a[i].tiers.length)],
isSpecial: o.includes(i) && 8 > Math.floor(100 * Math.random())
},
claimReady: !1
}),
setTimeout(function() {
t().stateNode.setState({
claimReady: !0
})
}, 1600),
t().stateNode.state.hackFish = null
} else
r.apply(this, arguments)
}
}
window.functionSet = !0,
! function e(o) {
if (Object.keys(a).includes(o))
t().stateNode.state.hackFish = o;
else {
alert("That fish does not exist!");
return
}
}
(e)
}
}, {
name: "Set Lure",
description: "Sets fishing lure (range 1 - 5)",
inputs: [{
name: "Lure (1 - 5)",
type: "number",
min: 1,
max: 5,
}, ],
run: function(lure) {
getStateNode().setState({
lure: Math.max(Math.min(lure - 1, 4), 0)
});
},
},
{
name: "Set Weight",
description: "Sets weight",
inputs: [{
name: "Weight",
type: "text",
}, ],
run: function(weight) {
let stateNode = getStateNode();
stateNode.setState({
weight,
weight2: weight
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}`,
val: {
b: stateNode.props.client.blook,
w: weight,
f: ["Crab", "Jellyfish", "Frog", "Pufferfish", "Octopus", "Narwhal", "Megalodon", "Blobfish", "Baby Shark"][Math.floor(Math.random() * 9)],
},
});
},
},
],
},
fishsolo: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Fishing_Frenzy_Logo_Resized.png",
name: "Fishing Frenzy (Solo Mode)",
cheats: [{
name: "Set Lure",
description: "Sets your lure level",
type: "button",
inputs: [{
name: "Lure (1 - 5)",
type: "number",
min: 1,
max: 5,
}, ],
run: function(lure) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
const input = lure;
iframe.remove();
if (!input) return;
const targetInternal = parseInt(input) - 1; // UI Level 1-5 -> Internal 0-4
if (isNaN(targetInternal) || targetInternal < 0 || targetInternal > 4) {
return alert("❌ Please enter a number between 1 and 5.");
}
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return;
let success = false;
function findAndDispatch(node) {
if (success || !node) return;
if (node.memoizedProps && typeof node.memoizedProps.lureLevel === 'number') {
const currentLevel = node.memoizedProps.lureLevel;
let parent = node.return;
while (parent) {
if (parent.memoizedState) {
let hook = parent.memoizedState;
let i = 0;
while (hook) {
if (i === 2 && hook.queue?.dispatch) {
if (hook.memoizedState === currentLevel) {
hook.queue.dispatch(targetInternal);
success = true;
return;
}
}
hook = hook.next;
i++;
}
}
parent = parent.return;
}
}
findAndDispatch(node.child);
findAndDispatch(node.sibling);
}
findAndDispatch(root[rKey]);
if (success) {
alert(`✅ Lure Level permanently set to ${targetInternal + 1}!`);
} else {
alert("❌ Could not find Lure State Hook. Try catching one fish first.");
}
})();
},
}, {
name: "Set Weight",
description: "Sets your weight",
type: "button",
inputs: [{
name: "Weight",
type: "text"
}, ],
run: function(weight) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
const input = weight;
iframe.remove();
if (!input) return;
const NEW_WEIGHT = parseFloat(input);
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return console.log("❌ React Root not found");
let success = false;
function findAndSet(node) {
if (success || !node) return;
if (node.memoizedState) {
let hook = node.memoizedState;
let i = 0;
while (hook) {
if (i === 2 && hook.queue?.dispatch) {
const currentVal = hook.memoizedState;
if (typeof currentVal === 'number') {
hook.queue.dispatch(NEW_WEIGHT);
success = true;
return;
}
}
hook = hook.next;
i++;
}
}
findAndSet(node.child);
findAndSet(node.sibling);
}
findAndSet(root[rKey]);
if (success) {
alert(`✅ Weight set to ${NEW_WEIGHT.toLocaleString()}!\n\nCatch a fish to update the UI.`);
} else {
alert("❌ Could not find Weight Hook. Catch one fish first!");
}
})();
},
}]
},
pirate: {
img: "https://media.blooket.com/image/upload/v1695317816/Media/logos/PiratesVoyageLogoSmall.png",
name: "Pirate's Voyage",
cheats: [{
name: "Heist ESP",
description: "Shows you what's under each chest during a heist",
type: "toggle",
enabled: false,
data: null,
imgs: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
const stateNode = getStateNode();
if (stateNode.state.stage != "heist") return;
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);
const esp = Object.values(document.querySelector("[class*=modal]"))[0].return.memoizedState.memoizedState;
for (const e of document.querySelectorAll("[class*=boxContent] > div")) e.remove();
const open = Object.values(document.querySelector("[class*=modal]"))[0].return.memoizedState.next.next.memoizedState;
Array.prototype.forEach.call(document.querySelector("[class*=chestsWrapper]").children, (container, i) => {
const box = container.firstChild.firstChild;
if (open.includes(i)) return (box.style.opacity = "");
box.style.opacity = "0.5";
let d = document.createElement("div");
d.innerHTML = "<img src='" + this.imgs[2 - esp[i]] + "' style='max-width: 75%; max-height: 75%'></img>";
d.className = "chestESP";
d.style.position = "absolute";
d.style.inset = "0";
d.style.display = "grid";
d.style.placeItems = "center";
d.style.pointerEvents = "none";
container.onclick = () => {
d.remove();
box.style.opacity = "";
};
container.firstChild.prepend(d);
});
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Max Levels",
description: "Maxes out all islands and your boat",
run: function() {
let stateNode = getStateNode();
stateNode.setState({
islandLevels: new Array(stateNode.state.islandLevels.length).fill(5)
}, stateNode.updateBoatLevel);
},
},
{
name: "Set Doubloons",
description: "Sets Doubloons",
inputs: [{
name: "Amount",
type: "number",
}, ],
run: function(doubloons) {
let stateNode = getStateNode();
stateNode.setState({
doubloons
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/d`,
val: doubloons,
});
},
},
{
name: "Start Heist",
description: "Starts a heist on someone",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: function(target) {
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", function(val) {
if (val?.[target])
stateNode.setState({
stage: "heist",
heistInfo: {
name: target,
blook: val[target].b
},
prizeAmount: Math.max(1000, val[target].d || 0),
});
});
},
},
{
name: "Swap Doubloons",
description: "Swaps Doubloons with someone",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: async function(target) {
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", function(val) {
if (!val?.[target]) return;
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}`,
val: {
b: stateNode.props.client.blook,
d: val[target].d,
tat: `${target}:${val[target].d - stateNode.state.doubloons}`,
},
});
stateNode.setState({
doubloons: val[target].d
});
});
},
},
{
name: "Take Doubloons",
description: "Takes Doubloons from someone",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: async function(target) {
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", function(val) {
if (!val?.[target]) return;
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}`,
val: {
b: stateNode.props.client.blook,
d: stateNode.state.doubloons + val[target].d,
tat: `${target}:${val[target].d}`,
},
});
stateNode.setState({
doubloons: stateNode.state.doubloons + val[target].d
});
});
},
},
],
},
defense2: {
img: "https://media.blooket.com/image/upload/v1676079918/Media/logos/Tower_Defense_2_Logo_Resize.png",
name: "Tower Defense 2",
cheats: [{
name: "Max Tower Stats",
description: "Makes all placed towers overpowered",
run: function() {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
iframe.remove();
function withScene(callback) {
if (window._SCENE && window._SCENE.sys && window._SCENE.sys.isActive()) {
callback(window._SCENE);
return;
}
let found = false;
const originalUpdate = window.Phaser.Scenes.SceneManager.prototype.update;
window.Phaser.Scenes.SceneManager.prototype.update = function(time, delta) {
originalUpdate.call(this, time, delta);
if (found) return;
for (const scene of this.scenes) {
if (scene.sys.isActive() && scene.sys.settings.key !== 'Boot') {
window._SCENE = scene;
found = true;
window.Phaser.Scenes.SceneManager.prototype.update = originalUpdate;
callback(scene);
return;
}
}
};
}
withScene((scene) => {
const service = scene.towerService;
if (!service || !service.towers) {
alert("❌ Tower Service not found!");
return;
}
const towersDict = service.towers;
let totalUpgraded = 0;
Object.keys(towersDict).forEach(typeKey => {
const group = towersDict[typeKey];
let towers = [];
if (group.getChildren) towers = group.getChildren();
else if (group.children && group.children.entries) towers = group.children.entries;
else if (Array.isArray(group)) towers = group;
towers.forEach(tower => {
tower.cd = 0;
tower.fullCd = 1;
if (tower.stats) {
tower.stats.dmg = 1e+10;
tower.stats.range = 1e+10;
tower.stats.fireRate = 1e+10;
tower.stats.ghostDetect = true;
tower.stats.maxTargets = 1e+10;
if (tower.stats.numProjectiles) {
tower.stats.numProjectiles = 100;
}
}
if (tower.rangeCircle) {
tower.rangeCircle.radius = 1000;
}
totalUpgraded++;
});
});
if (totalUpgraded > 0) {
alert(`✅ Upgraded ${totalUpgraded} towers (DMG, Range, Ghost Hit)!`);
} else {
alert("⚠️ No active towers found.");
}
});
})();
},
},
{
name: "Kill Enemies",
description: "Kills all the enemies",
run: function() {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
iframe.remove();
function withScene(callback) {
if (window._SCENE && window._SCENE.sys && window._SCENE.sys.isActive()) {
callback(window._SCENE);
return;
}
let found = false;
const originalUpdate = window.Phaser.Scenes.SceneManager.prototype.update;
window.Phaser.Scenes.SceneManager.prototype.update = function(time, delta) {
originalUpdate.call(this, time, delta);
if (found) return;
for (const scene of this.scenes) {
if (scene.sys.isActive() && scene.sys.settings.key !== 'Boot') {
window._SCENE = scene;
found = true;
window.Phaser.Scenes.SceneManager.prototype.update = originalUpdate;
callback(scene);
return;
}
}
};
}
withScene((scene) => {
const enemyService = scene.enemyService;
if (!enemyService) {
alert("Enemy Service not found!");
return;
}
if (enemyService.enemyQueue) {
enemyService.enemyQueue.length = 0;
console.log("Cleared enemy queue");
}
if (enemyService.enemies?.children?.entries) {
let killed = 0;
enemyService.enemies.children.entries.forEach(enemy => {
if (enemy && enemy.hp && enemy.takeDamage) {
enemy.takeDamage(enemy.hp);
killed++;
}
});
console.log(`Killed ${killed} enemies`);
alert(`Killed ${killed} enemies!`);
} else {
alert("No enemies found");
}
});
})();
},
},
{
name: "Set Coins",
description: "Sets coins",
inputs: [{
name: "Coins",
type: "number",
}, ],
run: function(coins) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
window.prompt = iframe.contentWindow.prompt.bind(window);
iframe.remove();
function withScene(callback) {
if (window._SCENE && window._SCENE.sys && window._SCENE.sys.isActive()) {
callback(window._SCENE);
return;
}
let found = false;
const originalUpdate = window.Phaser.Scenes.SceneManager.prototype.update;
window.Phaser.Scenes.SceneManager.prototype.update = function(time, delta) {
originalUpdate.call(this, time, delta);
if (found) return;
for (const scene of this.scenes) {
if (scene.sys.isActive() && scene.sys.settings.key !== 'Boot') {
window._SCENE = scene;
found = true;
window.Phaser.Scenes.SceneManager.prototype.update = originalUpdate;
callback(scene);
return;
}
}
};
}
withScene((scene) => {
const manager = scene.gameManager;
if (!manager) {
alert("❌ Game Manager not found! (Wait for game to load)");
return;
}
const current = manager.coins;
const input = coins;
if (input !== null) {
const amount = parseInt(input);
if (!isNaN(amount)) {
manager.coins = amount;
alert(`✅ Coins set to ${amount}!\n\nNote: Buy something to update the display counter.`);
}
}
});
})();
},
},
{
name: "Set Health",
description: "Sets the amount of health you have",
inputs: [{
name: "Health",
type: "number",
}, ],
run: function(health) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
window.prompt = iframe.contentWindow.prompt.bind(window);
iframe.remove();
function withScene(callback) {
if (window._SCENE && window._SCENE.sys && window._SCENE.sys.isActive()) {
callback(window._SCENE);
return;
}
let found = false;
const originalUpdate = window.Phaser.Scenes.SceneManager.prototype.update;
window.Phaser.Scenes.SceneManager.prototype.update = function(time, delta) {
originalUpdate.call(this, time, delta);
if (found) return;
for (const scene of this.scenes) {
if (scene.sys.isActive() && scene.sys.settings.key !== 'Boot') {
window._SCENE = scene;
found = true;
window.Phaser.Scenes.SceneManager.prototype.update = originalUpdate;
callback(scene);
return;
}
}
};
}
withScene((scene) => {
const manager = scene.gameManager;
if (!manager) {
alert("❌ Game Manager not found!");
return;
}
let healthTarget = manager;
if (manager.health === undefined && scene.gameData && scene.gameData.health !== undefined) {
healthTarget = scene.gameData;
}
const current = healthTarget.health;
const input = health;
if (input !== null) {
const amount = parseInt(input);
if (!isNaN(amount)) {
healthTarget.health = amount;
alert(`✅ Health set to ${amount}!\n\nNote: only changes the health that it shows if you take any damage.`);
}
}
});
})();
},
},
{
name: "Set Round",
description: "Sets the current round",
inputs: [{
name: "Round",
type: "number",
}, ],
run: function(round) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
window.prompt = iframe.contentWindow.prompt.bind(window);
iframe.remove();
function withScene(callback) {
if (window._SCENE && window._SCENE.sys && window._SCENE.sys.isActive()) {
callback(window._SCENE);
return;
}
let found = false;
const originalUpdate = window.Phaser.Scenes.SceneManager.prototype.update;
window.Phaser.Scenes.SceneManager.prototype.update = function(time, delta) {
originalUpdate.call(this, time, delta);
if (found) return;
for (const scene of this.scenes) {
if (scene.sys.isActive() && scene.sys.settings.key !== 'Boot') {
window._SCENE = scene;
found = true;
window.Phaser.Scenes.SceneManager.prototype.update = originalUpdate;
callback(scene);
return;
}
}
};
}
withScene((scene) => {
const enemyService = scene.enemyService;
if (!enemyService) {
alert("❌ Enemy Service not found! (Wait for game to load)");
return;
}
const current = enemyService.waveNum;
const input = round;
if (input !== null) {
const amount = parseInt(input);
if (!isNaN(amount)) {
enemyService.waveNum = amount;
alert(`✅ Round/Wave set to ${amount}!\n\nNote: You must finish the current wave for the game to jump to the new round.`);
if (enemyService.isWaveActive === false) {
if (scene.hud && scene.hud.updateWave) scene.hud.updateWave();
}
}
}
});
})();
},
},
],
},
brawl: {
img: "https://media.blooket.com/image/upload/v1663366470/Media/logos/Monster_Brawl_270x156_1.png",
name: "Monster Brawl",
cheats: [{
name: "Double Enemy XP",
description: "Doubles enemy XP drop value",
run: function() {
(() => {
console.log("💎 Double Enemy XP - Continuous Mode\n");
if (!window.Phaser) {
alert("Phaser not found!");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
let totalModified = 0;
window._processedEnemies = window._processedEnemies || new Set();
if (window.Phaser.GameObjects?.Group?.prototype && !window._groupHooked) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
console.log("✓ Group hook installed");
window._groupHooked = true;
}
}
const monitor = setInterval(() => {
if (!window._groups) return;
window._groups.forEach(group => {
if (!group.children?.entries) return;
group.children.entries.forEach(enemy => {
if (window._processedEnemies.has(enemy)) return;
if (enemy.val !== undefined && enemy.val !== null) {
const oldVal = enemy.val;
enemy.val *= 2;
window._processedEnemies.add(enemy);
totalModified++;
if (totalModified <= 10) {
console.log(`✓ Doubled enemy: ${oldVal} → ${enemy.val}`);
}
}
});
});
}, 5);
setTimeout(() => {
console.log("\n=== STATUS ===");
console.log(`Enemies modified: ${totalModified}`);
if (totalModified > 0) {
console.log("\n✅ DOUBLE XP ACTIVE!");
alert(`✅ Double Enemy XP Activated!\n\n${totalModified} enemies modified!\n\n🔄 Continuous monitoring: New enemies auto-doubled every 5ms`);
}
console.log("\n🔄 Continuous monitoring active (every 5ms)");
}, 2000);
console.log("⏳ Monitoring started...");
console.log("Play the game normally!");
window._xpMonitor = monitor;
})();
},
},
{
name: "Half Enemy Speed",
description: "Makes enemies move 2x slower",
run: function() {
(() => {
console.log("🐌 Half Enemy Speed - Continuous Mode\n");
if (!window.Phaser) {
alert("Phaser not found!");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
let totalSlowed = 0;
window._processedSpeeds = window._processedSpeeds || new Set();
if (window.Phaser.GameObjects?.Group?.prototype && !window._groupHookedSpeed) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
console.log("✓ Group hook installed");
window._groupHookedSpeed = true;
}
}
const monitor = setInterval(() => {
if (!window._groups) return;
window._groups.forEach(group => {
if (!group.children?.entries) return;
group.children.entries.forEach(enemy => {
if (window._processedSpeeds.has(enemy)) return;
if (enemy.speed !== undefined && enemy.speed !== null) {
const oldSpeed = enemy.speed;
enemy.speed *= 0.5;
window._processedSpeeds.add(enemy);
totalSlowed++;
if (totalSlowed <= 10) {
console.log(`✓ Slowed enemy: ${oldSpeed} → ${enemy.speed}`);
}
}
});
});
}, 5);
setTimeout(() => {
console.log("\n=== STATUS ===");
console.log(`Enemies slowed: ${totalSlowed}`);
if (totalSlowed > 0) {
console.log("\n✅ HALF SPEED ACTIVE!");
alert(`✅ Half Enemy Speed Activated!\n\n${totalSlowed} enemies slowed!\n\n🔄 Continuous monitoring: New enemies auto-slowed every 5ms`);
}
console.log("\n🔄 Continuous monitoring active (every 5ms)");
}, 2000);
console.log("⏳ Monitoring started...");
console.log("Play the game normally!");
window._speedMonitor = monitor;
})();
},
},
{
name: "Instant Kill",
description: "Sets all enemies health to 1",
run: function() {
(() => {
console.log("⚡ Instant Kill - Continuous Mode\n");
if (!window.Phaser) {
alert("❌ Phaser not found! Make sure you're in Monster Brawl.");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
let totalModified = 0;
window._processedInstantKill = window._processedInstantKill || new Set();
if (window.Phaser.GameObjects?.Group?.prototype && !window._groupHookedInstantKill) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
console.log("✓ Group hook installed");
window._groupHookedInstantKill = true;
}
}
if (window.Phaser.GameObjects?.GameObjectFactory?.prototype?.existing && !window._factoryHookedInstantKill) {
const originalExisting = window.Phaser.GameObjects.GameObjectFactory.prototype.existing;
window.Phaser.GameObjects.GameObjectFactory.prototype.existing = function(gameObject) {
const result = originalExisting.apply(this, arguments);
if (result && result.hp !== undefined && !window._processedInstantKill.has(result)) {
result.hp = 1;
window._processedInstantKill.add(result);
console.log(`✓ Auto-set new enemy HP to 1`);
}
return result;
};
console.log("✓ GameObjectFactory.existing hooked");
window._factoryHookedInstantKill = true;
}
const monitor = setInterval(() => {
if (!window._groups) return;
window._groups.forEach(group => {
if (!group.children?.entries) return;
group.children.entries.forEach(enemy => {
if (window._processedInstantKill.has(enemy)) return;
if (enemy.hp !== undefined && enemy.hp !== null) {
const oldHp = enemy.hp;
enemy.hp = 1;
window._processedInstantKill.add(enemy);
totalModified++;
if (totalModified <= 10) {
console.log(`✓ Enemy HP: ${oldHp} → 1`);
}
}
});
if (group.classType?.prototype && !group.classType.prototype._instantKillHooked) {
const methods = ['start', 'init', 'create'];
methods.forEach(method => {
if (group.classType.prototype[method]) {
const original = group.classType.prototype[method];
group.classType.prototype[method] = function(...args) {
const result = original.apply(this, args);
if (this.hp !== undefined) {
this.hp = 1;
}
return result;
};
}
});
group.classType.prototype._instantKillHooked = true;
}
});
}, 5);
setTimeout(() => {
console.log("\n=== STATUS ===");
console.log(`Enemies modified: ${totalModified}`);
if (totalModified > 0) {
console.log("\n✅ INSTANT KILL ACTIVE!");
alert(`✅ Instant Kill Activated!\n\n${totalModified} enemies now have 1 HP!\n\n🔄 Continuous monitoring: New enemies auto-modified every 5ms`);
} else {
console.log("\n⚠️ No enemies found yet");
console.log("Play a bit and enemies will be modified automatically!");
}
console.log("\n🔄 Continuous monitoring active (every 5ms)");
console.log("All enemies will die in one hit!");
}, 2000);
console.log("⏳ Monitoring started...");
console.log("Play the game normally!");
window._instantKillMonitor = monitor;
})();
},
},
{
name: "Invincibility",
description: "Makes you invincible",
run: function() {
(() => {
console.log("🎮 Blooket Brawl Invincibility - Continuous Mode\n");
if (!window.Phaser) {
alert("Phaser not found!");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
let playerFound = false;
let collidersDisabled = 0;
const monitor = setInterval(() => {
if (window.Phaser.GameObjects?.Sprite) {
const originalUpdate = window.Phaser.GameObjects.Sprite.prototype.preUpdate;
if (!window._invincibilityHooked) {
window.Phaser.GameObjects.Sprite.prototype.preUpdate = function(time, delta) {
if (!window._sprites) window._sprites = new Set();
window._sprites.add(this);
if (this.texture?.key?.includes('player') ||
this.texture?.key?.includes('blook') ||
this.name?.includes('player')) {
if (!window._player) {
console.log("✓✓✓ FOUND PLAYER!");
window._player = this;
playerFound = true;
}
if (this.setData) {
this.setData('invulnerable', true);
this.setData('invulnerableTime', Infinity);
this.setData('dmgCd', Infinity);
}
}
return originalUpdate?.apply(this, arguments);
};
window._invincibilityHooked = true;
console.log("✓ Sprite hook installed");
}
}
if (window.Phaser.Physics?.Arcade?.Body && !window._bodyHooked) {
const originalUpdate = window.Phaser.Physics.Arcade.Body.prototype.preUpdate;
window.Phaser.Physics.Arcade.Body.prototype.preUpdate = function() {
if (this.gameObject?.texture?.key?.includes('player') ||
this.gameObject?.texture?.key?.includes('blook')) {
if (!window._playerBody) {
window._playerBody = this;
}
this.onCollide = false;
this.onWorldBounds = false;
}
return originalUpdate?.apply(this, arguments);
};
window._bodyHooked = true;
console.log("✓ Body hook installed");
}
if (window.Phaser.Physics?.Arcade?.World && !window._worldHooked) {
const proto = window.Phaser.Physics.Arcade.World.prototype;
if (proto.collideObjects) {
const originalCollide = proto.collideObjects;
proto.collideObjects = function(body1, body2, collideCallback, processCallback, callbackContext) {
if (body1 === window._playerBody || body2 === window._playerBody) {
return false;
}
return originalCollide.apply(this, arguments);
};
}
if (proto.separate) {
const originalSeparate = proto.separate;
proto.separate = function(body1, body2, processCallback, callbackContext, overlapOnly) {
if (body1 === window._playerBody || body2 === window._playerBody) {
return false;
}
return originalSeparate.apply(this, arguments);
};
}
window._worldHooked = true;
console.log("✓ World collision hooks installed");
}
}, 5);
setTimeout(() => {
console.log("\n=== STATUS ===");
console.log("Player found:", playerFound ? "✓" : "✗");
if (playerFound) {
console.log("\n✅ INVINCIBILITY ACTIVE!");
alert("✅ Invincibility Activated!\n\nYou are now invincible!");
console.log("\n🔄 Continuous monitoring active (every 5ms)");
console.log("New enemies will be handled automatically!");
}
}, 3000);
console.log("⏳ Monitoring started...");
console.log("Move around in the game!");
window._invincibilityMonitor = monitor;
})();
},
},
{
name: "Kill Enemies",
description: "Kills all current enemies",
run: function() {
(() => {
console.log("💀 Kill All Enemies - Starting...\n");
if (!window.Phaser) {
alert("❌ Phaser not found! Make sure you're in Monster Brawl.");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
if (!window._groups || window._groups.size === 0) {
console.log("⏳ Collecting groups first...");
if (window.Phaser.GameObjects?.Group?.prototype) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate && !window._groupHookedKill) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
window._groupHookedKill = true;
}
}
setTimeout(killAllEnemies, 500);
} else {
killAllEnemies();
}
function killAllEnemies() {
console.log("\n=== KILLING ALL ENEMIES (WITH XP DROPS) ===\n");
if (!window._groups || window._groups.size === 0) {
alert("❌ No groups found! Play a bit first, then run this script again.");
return;
}
let totalKilled = 0;
let killedWithXP = 0;
let totalAttempted = 0;
const groups = Array.from(window._groups);
console.log(`Checking ${groups.length} groups...\n`);
groups.forEach((group, groupIndex) => {
if (!group.children?.entries) return;
const children = group.children.entries;
if (children.length === 0) return;
children.forEach((enemy, enemyIndex) => {
const texture = enemy.texture?.key || "";
if (texture.includes('player')) return;
totalAttempted++;
if (typeof enemy.receiveDamage === 'function' && enemy.hp !== undefined) {
try {
const hp = enemy.hp || 9999;
enemy.receiveDamage(hp, 1);
totalKilled++;
killedWithXP++;
if (killedWithXP <= 5) {
console.log(`✓ Killed enemy (HP: ${hp}) - XP will drop`);
}
return;
} catch (e) {
console.log(` ⚠️ receiveDamage failed:`, e.message);
}
}
if (enemy.hp !== undefined) {
try {
const oldHp = enemy.hp;
enemy.hp = 0;
if (typeof enemy.die === 'function') {
enemy.die();
totalKilled++;
killedWithXP++;
if (killedWithXP <= 5) {
console.log(`✓ Killed via die() method`);
}
return;
} else if (typeof enemy.death === 'function') {
enemy.death();
totalKilled++;
killedWithXP++;
if (killedWithXP <= 5) {
console.log(`✓ Killed via death() method`);
}
return;
}
} catch (e) {}
}
if (enemy.body) {
try {
if (typeof enemy.receiveDamage === 'function') {
enemy.receiveDamage(99999, 1);
totalKilled++;
killedWithXP++;
return;
}
} catch (e) {}
}
try {
enemy.hp = 0;
enemy.setVisible(false);
enemy.setActive(false);
if (enemy.emit) {
enemy.emit('death');
enemy.emit('killed');
}
totalKilled++;
if (totalKilled <= 5) {
console.log(`✓ Disabled enemy (may not drop XP)`);
}
} catch (e) {}
});
});
console.log("\n\n=== SUMMARY ===");
console.log(`Enemies found: ${totalAttempted}`);
console.log(`Enemies killed: ${totalKilled}`);
console.log(`Killed with XP drops: ${killedWithXP}`);
if (killedWithXP > 0) {
console.log("\n✅ SUCCESS!");
alert(`✅ Killed All Enemies!\n\n${killedWithXP} enemies eliminated!\n💎 XP should drop normally!`);
} else if (totalKilled > 0) {
console.log("\n⚠️ Killed enemies but XP drops not guaranteed");
alert(`⚠️ Killed ${totalKilled} enemies!\n\nHowever, XP drops may not work properly.\nTry using Instant Kill for guaranteed one-hit kills with XP!`);
} else {
console.log("\n⚠️ No enemies found");
alert("⚠️ No enemies found on screen!\nMake sure you're actively playing.");
}
}
})();
},
},
{
name: "Magnet",
description: "Pulls all xp towards you",
run: function() {
(() => {
console.log("🧲 Permanent Magnet\n");
if (!window.Phaser) {
alert("❌ Phaser not found!");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
if (window.Phaser.GameObjects?.Group?.prototype && !window._groupHooked) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
console.log("✓ Group hook installed");
window._groupHooked = true;
}
}
console.log("\n⏳ Waiting for scene...");
setTimeout(() => {
if (!window._groups || window._groups.size === 0) {
alert("❌ Scene not found! Make sure you're playing!");
return;
}
const scene = Array.from(window._groups)[0].scene;
if (!scene || !scene.playerService || !scene.playerService.player) {
alert("❌ Player not found!");
return;
}
const player = scene.playerService.player;
console.log("\n🧲 Current magnetTime:", player.magnetTime);
player.magnetTime = 999999;
console.log("✅ New magnetTime:", player.magnetTime);
console.log("\n🧲 Permanent magnet activated!");
console.log("All drops will now be attracted to you!");
alert("✅ Permanent Magnet!\n\n🧲 You now have a magnet effect for 999999 seconds!\n\nAll XP and items will be pulled to you automatically!");
}, 1000);
})();
},
},
{
name: "Make Abilities OP",
description: "Maxes out all your current abilities and makes them insanely powerful",
run: function() {
(() => {
const SIZE_MULTIPLIER = 5;
const CHECK_INTERVAL = 3000;
if (window._autoOpAbilitiesRunning) {
alert("❌ Script is already running!");
return;
}
window._autoOpAbilitiesRunning = true;
console.log(`💥 Auto OP Abilities (${SIZE_MULTIPLIER}x Size)\n`);
console.log("⏰ Checking every 3 seconds for new abilities...\n");
if (!window.Phaser) {
alert("❌ Phaser not found!");
return;
}
console.log("✓ Phaser", window.Phaser.VERSION);
window._processedAbilities = window._processedAbilities || new Set();
window._originalWidths = window._originalWidths || {};
if (window.Phaser.GameObjects?.Group?.prototype && !window._groupHooked) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._groups) window._groups = new Set();
window._groups.add(this);
return originalUpdate?.apply(this, args);
};
console.log("✓ Group hook installed");
window._groupHooked = true;
}
}
let totalUnlocked = 0;
let totalModified = 0;
const processAbilities = () => {
if (!window._groups || window._groups.size === 0) return;
const scene = Array.from(window._groups)[0].scene;
if (!scene || !scene.abilityService) return;
Object.keys(scene.abilityService.abilityStats).forEach(ability => {
if (window._processedAbilities.has(ability)) return;
const stats = scene.abilityService.abilityStats[ability];
console.log(`\n🆕 New ability detected: ${ability}`);
if (stats.width !== undefined) {
window._originalWidths[ability] = stats.width;
}
if (scene.abilityService.abilityLevels[ability] === undefined) {
scene.abilityService.abilityLevels[ability] = 1;
console.log(` 🔓 Unlocked!`);
totalUnlocked++;
}
if (stats.dmg !== undefined) {
stats.dmg = 9999;
}
if (stats.fireRate !== undefined) {
stats.fireRate = 50;
}
if (stats.maxTargets !== undefined) {
stats.maxTargets = 999;
}
if (stats.numProjectiles !== undefined) {
stats.numProjectiles = 50;
}
if (stats.speed !== undefined) {
stats.speed = 2000;
}
if (stats.lifespan !== undefined && stats.lifespan > 0) {
stats.lifespan = 10000;
}
if (stats.knockback !== undefined) {
stats.knockback = 5;
}
if (stats.width !== undefined && window._originalWidths[ability]) {
const originalWidth = window._originalWidths[ability];
stats.width = Math.round(originalWidth * SIZE_MULTIPLIER);
console.log(` 📏 Size: ${originalWidth} → ${stats.width} (${SIZE_MULTIPLIER}x)`);
}
if (stats.intervalRate !== undefined) {
stats.intervalRate = 10;
}
console.log(` ✅ ${ability} is now OP!`);
window._processedAbilities.add(ability);
totalModified++;
});
};
setTimeout(() => {
console.log("\n🔍 Initial scan...");
processAbilities();
if (totalModified > 0) {
console.log(`\n✅ Initial scan complete!`);
console.log(`🔓 Unlocked: ${totalUnlocked}`);
console.log(`💥 Modified: ${totalModified}`);
}
}, 1000);
const monitor = setInterval(() => {
processAbilities();
}, CHECK_INTERVAL);
window._autoOpMonitor = monitor;
console.log("\n✅ Auto OP script started!");
console.log(`⏰ Monitoring every ${CHECK_INTERVAL/1000} seconds`);
console.log(`📏 Size multiplier: ${SIZE_MULTIPLIER}x`);
console.log("\n💡 New abilities will be automatically made OP!");
console.log("💡 To stop: clearInterval(window._autoOpMonitor)");
})();
},
},
{
name: "Set XP",
description: "Sets your XP",
inputs: [{
name: "Amount",
type: "number"
}],
run: function(xp) {
(() => {
console.log("💎 Set XP\n");
if (window.Phaser?.GameObjects?.Group?.prototype && !window._xpSceneHook) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._scene && this.scene) {
window._scene = this.scene;
console.log("✓ Scene captured!");
}
return originalUpdate?.apply(this, args);
};
window._xpSceneHook = true;
}
}
console.log("✓ Phaser hook installed");
console.log("⏳ Waiting for scene...");
console.log("\nMove around in the game to activate!");
let checkCount = 0;
const checkInterval = setInterval(() => {
checkCount++;
if (checkCount % 10 === 0) {
console.log(` Still waiting... (${checkCount / 2}s) - Move around!`);
}
if (window._scene?.gameManager) {
clearInterval(checkInterval);
const gm = window._scene.gameManager;
console.log("\n✓✓✓ Scene found!");
console.log("Current XP:", gm.totalXp);
console.log("Current Level:", gm.level);
console.log("Status:", gm.status);
const newXp = xp;
if (newXp !== null) {
const xp = parseInt(newXp);
if (isNaN(xp)) {
alert("❌ Invalid number!");
return;
}
gm.totalXp = xp;
gm.curXp = xp;
window._scene.eventBus.emit('xp-updated', xp);
console.log("✅ XP set to:", xp);
alert(`✅ XP Set!\n\nNew XP: ${xp}\nLevel: ${gm.level}`);
} else {
console.log("Cancelled");
}
}
}, 200);
setTimeout(() => {
if (window._scene?.gameManager) return;
clearInterval(checkInterval);
console.log("\n❌ Timeout - scene not found after 60 seconds");
alert("❌ Timeout!\n\nMove around in the game and try again.");
}, 60000);
})();
},
},
{
name: "Reset Health",
description: "Resets health and gives invincibility for 3 seconds",
run: function() {
(() => {
console.log("❤️ Reset Health\n");
if (window.Phaser?.GameObjects?.Group?.prototype && !window._healthHook) {
const originalUpdate = window.Phaser.GameObjects.Group.prototype.preUpdate ||
window.Phaser.GameObjects.Group.prototype.update;
if (originalUpdate) {
window.Phaser.GameObjects.Group.prototype.preUpdate = function(...args) {
if (!window._scene && this.scene) {
window._scene = this.scene;
}
return originalUpdate?.apply(this, args);
};
window._healthHook = true;
}
}
setTimeout(() => {
if (!window._scene?.eventBus) {
alert("❌ Scene not found! Move around and try again.");
return;
}
try {
const respawnEvent = window._scene.eventBus._events?.respawn;
if (respawnEvent?.fn) {
console.log("✓ Found respawn event");
respawnEvent.fn();
console.log("✅ Health reset!");
alert("✅ Health Reset!\n\nYour health is now full!");
} else if (respawnEvent && typeof respawnEvent === 'function') {
respawnEvent();
console.log("✅ Health reset!");
alert("✅ Health Reset!\n\nYour health is now full!");
} else {
window._scene.eventBus.emit('respawn');
console.log("✅ Respawn event emitted!");
alert("✅ Health Reset!\n\nRespawn triggered!");
}
} catch (e) {
console.log("❌ Error:", e);
alert(`❌ Error: ${e.message}`);
}
}, 1000);
console.log("⏳ Getting scene...");
})();
},
},
],
},
dino: {
// img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Deceptive_Dinos_Logo_Resized.png",
img: "",
name: "Deceptive Dinos",
cheats: [{
name: "Auto Choose",
description: "Automatically choose the best fossil when excavating",
type: "toggle",
enabled: false,
data: null,
rand(e, t) {
const s = [];
while (s.length < t) {
const i = Math.random();
let r = 0,
g = null;
for (let o = 0; o < e.length; o++) {
r += e[o].rate;
if (r >= i) {
g = e[o];
break;
}
}
g && !s.includes(g) && s.push(g);
}
return s;
},
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
try {
let stateNode = getStateNode();
if (stateNode.state.stage === "excavate") {
stateNode.state.choices.length ||
(stateNode.state.choices = this.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
));
let max = 0,
index = -1;
for (let i = 0; i < stateNode.state.choices.length; i++) {
const {
type,
val
} = stateNode.state.choices[i];
const value = (type == "fossil" ? stateNode.state.fossils + val * stateNode.state.fossilMult : stateNode.state.fossils * val) || 0;
if (value <= max && type != "mult") continue;
(max = value), (index = i + 1);
}
document.querySelector('div[class*=rockRow] > div[role="button"]:nth-child(' + index + ")").click();
}
} catch {}
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Rock ESP",
description: "Shows what is under the rocks",
type: "toggle",
enabled: false,
data: null,
run: (() => {
function rand(e, t) {
const s = [];
while (s.length < t) {
const i = Math.random();
let r = 0;
let g;
for (let o = 0; o < e.length; o++) {
r += e[o].rate;
if (r >= i) {
g = e[o];
break;
}
}
if (g && !s.includes(g)) s.push(g);
}
return s;
}
const exps = ["⁰", "¹", "²", "³", "⁴", "⁵", "⁶", "⁷", "⁸", "⁹"];
const getExpAscii = (num) => {
let res = "";
while (num > 0) {
res = exps[num % 10] + res;
num = ~~(num / 10);
}
return res;
};
function shortNum(value) {
let newValue = value.toString();
if (value >= 1000) {
const suffixes = ["", "K", "M", "B", "T"];
const suffixNum = Math.floor(Math.floor((Math.log(value) / Math.log(10)).toPrecision(14)) / 3);
if (suffixNum < suffixes.length) {
let shortValue = "";
for (let precision = 3; precision >= 1; precision--) {
shortValue = parseFloat((suffixNum != 0 ? value / Math.pow(1000, suffixNum) : value).toPrecision(precision)).toString();
const dotLessShortValue = shortValue.replace(/[^a-zA-Z 0-9]+/g, "");
if (dotLessShortValue.length <= 3) break;
}
if (Number(shortValue) % 1 != 0) shortValue = Number(shortValue).toFixed(1);
newValue = shortValue + suffixes[suffixNum];
} else {
let num = value;
let exp = 0;
while (num >= 100) {
num = Math.floor(num / 10);
exp += 1;
}
newValue = num / 10 + " × 10" + getExpAscii(exp + 1);
}
}
return newValue;
}
return function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
let stateNode = getStateNode();
const rocks = document.querySelector('[class*="rockButton"]').parentElement.children;
if (!Array.prototype.every.call(rocks, (element) => element.querySelector("div")))
stateNode.setState({
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
),
},
() => {
Array.prototype.forEach.call(rocks, (element, index) => {
const rock = stateNode.state.choices[index];
if (element.querySelector("div")) element.querySelector("div").remove();
const choice = document.createElement("div");
choice.style.color = "white";
choice.style.fontFamily = "Macondo";
choice.style.fontSize = "1em";
choice.style.display = "flex";
choice.style.justifyContent = "center";
choice.style.transform = "translateY(25px)";
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`;
element.append(choice);
});
}
);
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
};
})(),
},
{
name: "Set Fossils",
description: "Sets the amount of fossils you have",
inputs: [{
name: "Fossils",
type: "number",
}, ],
run: function(fossils) {
let stateNode = getStateNode();
stateNode.setState({
fossils
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/f`,
val: fossils,
});
},
},
{
name: "Set Multiplier",
description: "Sets fossil multiplier",
inputs: [{
name: "Multiplier",
type: "number",
}, ],
run: function(fossilMult) {
let stateNode = getStateNode();
stateNode.setState({
fossilMult
});
},
},
{
name: "Stop Cheating",
description: "Undoes cheating so that you can't be caught",
run: function() {
let stateNode = getStateNode();
stateNode.setState({
isCheating: false
});
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/ic`,
val: false,
});
},
},
],
},
royale: {
// img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Battle_Royale_Logo_Resized.png",
img: "",
name: "Battle Royale",
cheats: [{
name: "Auto Answer (Toggle)",
description: "Toggles auto answer on",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(() => {
let stateNode = getStateNode();
stateNode?.onAnswer?.(true, stateNode.props.client.question.correctAnswers[0]);
}, 50);
} else {
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
},
},
{
name: "Auto Answer",
description: "Chooses the correct answer for you",
run: function() {
let stateNode = getStateNode();
stateNode?.onAnswer?.(true, stateNode.props.client.question.correctAnswers[0]);
},
},
],
},
defense: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Tower_Defense_Logo_Resized.png",
name: "Tower Defense",
cheats: [{
name: "Max Tower Stats",
description: "Makes all placed towers overpowered",
run: function() {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
iframe.remove();
function searchDOM(element = document.body, depth = 0) {
if (depth > 5) return null;
const keys = Object.keys(element);
const reactKey = keys.find(k => k.includes('react'));
if (reactKey) {
try {
let fiber = element[reactKey];
while (fiber) {
const node = fiber.stateNode || (fiber._owner ? fiber._owner.stateNode : null);
if (node) {
if (node.towers && Array.isArray(node.towers)) return node;
if (node.state && node.state.round !== undefined) return node;
}
fiber = fiber.return;
}
} catch (e) {}
}
for (const child of element.children) {
const result = searchDOM(child, depth + 1);
if (result) return result;
}
return null;
}
const comp = searchDOM();
if (!comp) {
alert("❌ Component not found!");
return;
}
if (!comp.towers || comp.towers.length === 0) {
alert("⚠️ No towers found! Place a tower first.");
return;
}
console.log("Found Towers:", comp.towers);
comp.towers.forEach(tower => {
tower.range = 100;
tower.cd = 0;
tower.damage = 1000000;
if (tower.stats) {
tower.stats.damage = 1000000;
tower.stats.range = 100;
tower.stats.fireRate = 0.01;
}
});
alert(`✅ Upgraded ${comp.towers.length} towers!`);
if (comp.forceUpdate) comp.forceUpdate();
})();
},
},
{
name: "Remove Enemies",
description: "Removes all the enemies",
run: function() {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
iframe.remove();
function searchDOM(element = document.body, depth = 0) {
if (depth > 5) return null;
const keys = Object.keys(element);
const reactKey = keys.find(k => k.includes('react'));
if (reactKey) {
try {
let fiber = element[reactKey];
while (fiber) {
const node = fiber.stateNode || (fiber._owner ? fiber._owner.stateNode : null);
if (node) {
if (node.enemies && Array.isArray(node.enemies)) return node;
if (node.state && node.state.enemies) return node;
}
fiber = fiber.return;
}
} catch (e) {}
}
for (const child of element.children) {
const result = searchDOM(child, depth + 1);
if (result) return result;
}
return null;
}
const comp = searchDOM();
if (!comp) {
alert("❌ Component not found! Make sure you are in-game.");
return;
}
if (comp.enemies) {
const count = comp.enemies.length;
comp.enemies = [];
comp.futureEnemies = [];
if (comp.state && comp.state.enemies) {
comp.setState({
enemies: [],
futureEnemies: []
});
}
alert(`✅ Removed ${count} enemies and cleared the wave!`);
} else {
alert("⚠️ No enemies found to remove.");
}
})();
},
},
{
name: "Remove Obstacles",
description: "Lets you place towers anywhere",
run: function() {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.alert = iframe.contentWindow.alert.bind(window);
iframe.remove();
function searchDOM(element = document.body, depth = 0) {
if (depth > 5) return null;
const keys = Object.keys(element);
const reactKey = keys.find(k => k.includes('react'));
if (reactKey) {
try {
let fiber = element[reactKey];
while (fiber) {
const node = fiber.stateNode || (fiber._owner ? fiber._owner.stateNode : null);
if (node) {
if (node.tiles && Array.isArray(node.tiles)) return node;
}
fiber = fiber.return;
}
} catch (e) {}
}
for (const child of element.children) {
const result = searchDOM(child, depth + 1);
if (result) return result;
}
return null;
}
const comp = searchDOM();
if (!comp) {
alert("❌ Component not found! Make sure you are in-game.");
return;
}
if (comp.tiles && comp.tiles.length > 0) {
comp.tiles = comp.tiles.map(row => {
if (Array.isArray(row)) {
return new Array(row.length).fill(0);
}
return row;
});
if (comp.forceUpdate) comp.forceUpdate();
alert("✅ All obstacles removed! You can now place towers anywhere.");
} else {
alert("⚠️ No map tiles found.");
}
})();
},
},
{
name: "Set Damage",
description: "Sets damage",
inputs: [{
name: "Damage",
type: "number",
}, ],
run: function(dmg) {
(() => {
function getComp(element = document.body, depth = 0) {
if (depth > 20) return null;
const fiber = element[Object.keys(element).find(k => k.includes('react'))];
if (fiber) {
let curr = fiber;
while (curr) {
const sn = curr.stateNode || curr._owner?.stateNode;
if (sn?.state?.totalDamage !== undefined) return sn;
curr = curr.return;
}
}
for (const child of element.children) {
const result = getComp(child, depth + 1);
if (result) return result;
}
}
const sn = getComp();
if (!sn) return;
sn.setState({
totalDamage: Number(dmg)
});
})();
}
},
{
name: "Set Round",
description: "Sets the current round",
inputs: [{
name: "Round",
type: "number",
}, ],
run: function(round) {
(() => {
let iframe = document.createElement('iframe');
document.body.append(iframe);
window.prompt = iframe.contentWindow.prompt.bind(window);
iframe.remove();
function searchDOM(element = document.body, depth = 0) {
if (depth > 5) return null;
const keys = Object.keys(element);
const reactKey = keys.find(k => k.includes('react'));
if (reactKey) {
try {
let fiber = element[reactKey];
while (fiber) {
if (fiber._owner && fiber._owner.stateNode && fiber._owner.stateNode.state) {
const state = fiber._owner.stateNode.state;
if (state.round !== undefined) return fiber._owner.stateNode;
}
if (fiber.stateNode && fiber.stateNode.state) {
const state = fiber.stateNode.state;
if (state.round !== undefined) return fiber.stateNode;
}
fiber = fiber.return;
}
} catch (e) {}
}
for (const child of element.children) {
const result = searchDOM(child, depth + 1);
if (result) return result;
}
return null;
}
const comp = searchDOM();
if (!comp) {
alert("❌ Component not found!");
return;
}
comp.setState({
round
});
alert(`✅ Round set to ${round}!`);
})();
},
},
{
name: "Set Tokens",
description: "Sets the amount of tokens you have",
inputs: [{
name: "Tokens",
type: "number",
}, ],
run: function(tokens) {
(() => {
function getComp(element = document.body, depth = 0) {
if (depth > 20) return null;
const fiber = element[Object.keys(element).find(k => k.includes('react'))];
if (fiber) {
let curr = fiber;
while (curr) {
const sn = curr.stateNode || curr._owner?.stateNode;
if (sn?.state?.tokens !== undefined) return sn;
curr = curr.return;
}
}
for (const child of element.children) {
const result = getComp(child, depth + 1);
if (result) return result;
}
}
const sn = getComp();
if (!sn) return;
sn.setState({
tokens: Number(tokens)
});
})();
}
},
],
},
cafe: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Cafe_Logo_Resized.png",
name: "Café",
cheats: [{
name: "Max Items",
description: "Maxes out items in the shop (solo only)",
run: function() {
(() => {
let iframe = document.querySelector("iframe");
if (!iframe) {
iframe = document.createElement("iframe");
iframe.style.display = "none";
document.body.append(iframe);
}
const alert = iframe.contentWindow.alert.bind(window);
const cheat = () => {
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return alert("❌ React Root not found. Please reload.");
let success = false;
function traverse(node) {
if (success || !node) return;
if (node.memoizedState) {
let hook = node.memoizedState;
let index = 0;
let levelHook = null;
while (hook) {
if (index === 4) {
levelHook = hook;
break;
}
hook = hook.next;
index++;
}
if (levelHook) {
const val = levelHook.memoizedState;
if (val && typeof val === 'object' && !Array.isArray(val) && val.Toast !== undefined) {
const newLevels = {
...val
};
Object.keys(newLevels).forEach(key => {
if (typeof newLevels[key] === 'number') {
newLevels[key] = 5;
}
});
if (levelHook.queue && levelHook.queue.dispatch) {
levelHook.queue.dispatch(newLevels);
success = true;
alert("✅ All items upgraded to Level 5!");
}
}
}
}
traverse(node.child);
traverse(node.sibling);
}
traverse(root[rKey]);
if (!success) alert("❌ Cheat failed. Make sure you are in the game.");
};
cheat();
})();
},
},
{
name: "Set Cash",
description: "Sets cafe cash (only works in solo)",
inputs: [{
name: "Amount",
type: "number",
}, ],
run: function(cafeCash) {
(() => {
const iframe = document.createElement('iframe');
document.body.appendChild(iframe);
const prompt = iframe.contentWindow.prompt;
const amountStr = prompt("💸 ENTER DESIRED CASH AMOUNT:", "1000000");
document.body.removeChild(iframe);
if (!amountStr) return;
const newAmount = cafeCash;
if (isNaN(newAmount)) {
alert("❌ Invalid number entered.");
return;
}
console.clear();
console.log(`%c☕ APPLYING CASH HACK: $${newAmount.toLocaleString()}`, "color: #ff9900; font-weight: bold; font-size: 1.2em;");
function findCashDispatcher() {
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return null;
let result = null;
function traverse(node) {
if (result || !node) return;
if (node.memoizedState) {
let hook = node.memoizedState;
let depth = 0;
while (hook) {
const val = hook.memoizedState;
if (typeof val === 'number' && hook.queue && hook.queue.dispatch) {
if (depth > 5) {
if (!result) result = [];
result.push(hook.queue.dispatch);
}
}
hook = hook.next;
depth++;
}
}
traverse(node.child);
traverse(node.sibling);
}
traverse(root[rKey]);
return result;
}
function setCashByStructure() {
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
let found = false;
function traverse(node) {
if (found || !node) return;
if (node.memoizedState) {
let h = node.memoizedState;
try {
for (let i = 0; i < 8; i++) {
if (h) h = h.next;
}
if (h && h.memoizedState !== undefined && typeof h.memoizedState === 'number') {
let count = 0;
let temp = node.memoizedState;
while (temp) {
count++;
temp = temp.next;
}
if (count > 10 && h.queue && h.queue.dispatch) {
console.log(`%c⚡ Found candidate Hook (Value: ${h.memoizedState})`, "color: #00ff00");
h.queue.dispatch(newAmount);
found = true;
}
}
} catch (e) {}
}
traverse(node.child);
traverse(node.sibling);
}
if (rKey) traverse(root[rKey]);
return found;
}
const success = setCashByStructure();
if (success) {
console.log("%c✅ SUCCESS: Money Updated!", "background: green; color: white; padding: 5px; font-size: 1.2em");
alert(`💰 Cash set to ${newAmount.toLocaleString()}!\n\n(If it doesn't show immediately, buy something cheap to refresh)`);
} else {
console.log("❌ Could not pinpoint the exact hook automatically.");
console.log("⚠️ Fallback: Trying to set ALL deep numeric states...");
const dispatchers = findCashDispatcher();
if (dispatchers && dispatchers.length > 0) {
dispatchers.forEach(d => d(newAmount));
alert("⚠️ Brute-force update sent. Check your cash.");
} else {
alert("❌ Failed to find game state. Are you in the Café game?");
}
}
})();
},
},
{
name: "Stock Food",
description: "Stocks all food to 99 (Not usable in the shop) (Solo only)",
run: function() {
(() => {
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return;
let success = false;
function traverse(node) {
if (success || !node) return;
if (node.memoizedState) {
let hook = node.memoizedState;
let index = 0;
let hook4 = null;
let hook5 = null;
while (hook) {
if (index === 4) hook4 = hook;
if (index === 5) hook5 = hook;
if (index > 5) break;
hook = hook.next;
index++;
}
if (hook4 && hook5) {
const val4 = hook4.memoizedState;
const val5 = hook5.memoizedState;
if (val4 && val5 && typeof val4 === 'object' && typeof val5 === 'object' && val4.Toast !== undefined) {
const newLevels = {
...val4
};
Object.keys(newLevels).forEach(key => {
if (typeof newLevels[key] === 'number') newLevels[key] = 5;
});
const newStock = {
...val5
};
Object.keys(newStock).forEach(key => {
if (typeof newStock[key] === 'number') newStock[key] = 999;
});
hook4.queue.dispatch(newLevels);
hook5.queue.dispatch(newStock);
success = true;
}
}
}
traverse(node.child);
traverse(node.sibling);
}
traverse(root[rKey]);
})();
},
}, {
name: "Make Customers OP",
description: "Makes all customers pay a LOT (only works in solo)",
run: function() {
(() => {
if (window.opCustomerInterval) {
clearInterval(window.opCustomerInterval);
console.log("%c[makeCustomersOP] Restarting loop...", "color: orange");
}
const OP_VALUE = 99999999999999;
function scanAndModify() {
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return;
let totalModified = 0;
function traverse(node) {
if (!node) return;
if (node.memoizedState && typeof node.type === 'function') {
let hook = node.memoizedState;
while (hook) {
const data = hook.memoizedState;
if (data instanceof Map && data.size > 0) {
data.forEach((val) => {
if (val && typeof val === 'object' && val.order && typeof val.order.value === 'number') {
if (val.order.value !== OP_VALUE) {
val.order.value = OP_VALUE;
totalModified++;
}
}
});
}
hook = hook.next;
}
}
traverse(node.child);
traverse(node.sibling);
}
traverse(root[rKey]);
if (totalModified > 0) {
console.log(`%c[makeCustomersOP] Upgraded ${totalModified} new customers!`, 'color: #00ff00; font-weight: bold');
}
}
console.clear();
console.log("%c[makeCustomersOP] Activated! New customers will be rich.", "color: #00ff00; font-size: 16px; font-weight: bold");
window.opCustomerInterval = setInterval(scanAndModify, 500);
})();
}
}, {
name: "Make Upgrades Cheap",
description: "Makes most upggrades cheap",
run: function() {
(() => {
console.clear();
console.log("%c💸 SETTING COST: 1 | PROFIT: 9e99", "color: #ff00ff; font-weight: bold;");
const root = document.querySelector('#app') || document.body;
const rKey = Object.keys(root).find(k => k.startsWith('__reactFiber'));
if (!rKey) return console.log("❌ React Root not found");
let success = false;
function traverse(node) {
if (success || !node) return;
if (node.memoizedState) {
let hook = node.memoizedState;
let index = 0;
while(hook) {
if (index === 1) {
const val = hook.memoizedState;
if (val && typeof val === 'object' && val.toast && val.toast.prices) {
const newDefs = { ...val };
const items = Object.keys(newDefs);
items.forEach(key => {
const item = newDefs[key];
if (item && item.prices && item.profits) {
const cheapPrices = new Array(item.prices.length).fill(1);
const insaneProfits = new Array(item.profits.length).fill(9e99);
insaneProfits[0] = 0; // Keep lvl 0 safe
newDefs[key] = {
...item,
prices: cheapPrices,
profits: insaneProfits
};
}
});
if (hook.queue && hook.queue.dispatch) {
hook.queue.dispatch(newDefs);
success = true;
console.log("%c✅ DONE. Try upgrading now.", "color: #00ff00; font-weight: bold;");
}
}
}
hook = hook.next;
index++;
}
}
traverse(node.child);
traverse(node.sibling);
}
traverse(root[rKey]);
if (!success) console.log("❌ Failed to find definitions hook.");
})();
}
}
],
},
factory: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Factory_Logo_Resized.png",
name: "Factory",
cheats: [{
name: "Choose Blook",
description: "Gives you a blook",
inputs: [{
name: "Blook",
type: "options",
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)
})),
}, ],
run: function(blook) {
(() => {
console.clear();
console.log("🏭 Factory: Choose Blook...");
const factoryBlooks = [{
name: "Chick",
color: "#ffcd05",
class: "🌽",
rarity: "Common",
cash: [3, 7, 65, 400, 2500],
time: [1, 1, 1, 1, 1],
price: [300, 3000, 30000, 200000]
},
{
name: "Chicken",
color: "#ed1c24",
class: "🌽",
rarity: "Common",
cash: [10, 40, 200, 1400, 10000],
time: [5, 4, 3, 2, 1],
price: [570, 4000, 50000, 800000]
},
{
name: "Cow",
color: "#58595b",
class: "🌽",
rarity: "Common",
cash: [25, 75, 1500, 25000, 250000],
time: [15, 10, 10, 10, 5],
price: [500, 9500, 160000, 4000000]
},
{
name: "Duck",
color: "#4ab96d",
class: "🌽",
rarity: "Common",
cash: [4, 24, 200, 3000, 40000],
time: [3, 3, 3, 3, 3],
price: [450, 4200, 70000, 1100000]
},
{
name: "Goat",
color: "#c59a74",
class: "🌽",
rarity: "Common",
cash: [5, 28, 200, 1300, 12000],
time: [3, 3, 2, 2, 2],
price: [500, 6400, 45000, 500000]
},
{
name: "Horse",
color: "#995b3c",
class: "🌽",
rarity: "Common",
cash: [5, 20, 270, 1800, 15000],
time: [2, 2, 2, 2, 2],
price: [550, 8200, 65000, 600000]
},
{
name: "Pig",
color: "#f6a9cb",
class: "🌽",
rarity: "Common",
cash: [20, 50, 1300, 8000, 80000],
time: [7, 7, 7, 7, 5],
price: [400, 11000, 80000, 1300000]
},
{
name: "Sheep",
color: "#414042",
class: "🌽",
rarity: "Common",
cash: [6, 25, 250, 1500, 11000],
time: [3, 3, 3, 2, 2],
price: [500, 5000, 50000, 430000]
},
{
name: "Cat",
color: "#f49849",
class: "🐾",
rarity: "Common",
cash: [5, 18, 170, 1700, 13000],
time: [2, 2, 2, 2, 2],
price: [480, 5500, 60000, 500000]
},
{
name: "Dog",
color: "#995b3c",
class: "🐾",
rarity: "Common",
cash: [7, 25, 220, 1900, 9000],
time: [3, 3, 2, 2, 1],
price: [460, 6600, 70000, 730000]
},
{
name: "Goldfish",
color: "#f18221",
class: "🐾",
rarity: "Common",
cash: [5, 40, 350, 3500, 35000],
time: [3, 3, 3, 3, 3],
price: [750, 7200, 84000, 950000]
},
{
name: "Rabbit",
color: "#e7bf9a",
class: "🐾",
rarity: "Common",
cash: [3, 18, 185, 800, 7000],
time: [2, 2, 2, 1, 1],
price: [500, 5800, 56000, 550000]
},
{
name: "Hamster",
color: "#ce9176",
class: "🐾",
rarity: "Common",
cash: [10, 45, 450, 4500, 45000],
time: [4, 4, 4, 4, 4],
price: [650, 6500, 80000, 930000]
},
{
name: "Turtle",
color: "#619a3c",
class: "🐾",
rarity: "Common",
cash: [23, 120, 1400, 15000, 170000],
time: [10, 10, 10, 10, 10],
price: [700, 8500, 110000, 1300000]
},
{
name: "Puppy",
color: "#414042",
class: "🐾",
rarity: "Common",
cash: [4, 10, 75, 500, 3000],
time: [1, 1, 1, 1, 1],
price: [450, 4000, 35000, 250000]
},
{
name: "Kitten",
color: "#58595b",
class: "🐾",
rarity: "Common",
cash: [4, 8, 60, 400, 2000],
time: [1, 1, 1, 1, 1],
price: [350, 3500, 26000, 170000]
},
{
name: "Bear",
color: "#995b3c",
class: "🌲",
rarity: "Common",
cash: [12, 70, 550, 4500, 100000],
time: [7, 7, 6, 5, 5],
price: [550, 5500, 63000, 1600000]
},
{
name: "Moose",
color: "#995b3c",
class: "🌲",
rarity: "Common",
cash: [8, 45, 400, 3500, 26000],
time: [5, 5, 4, 4, 3],
price: [520, 6500, 58000, 700000]
},
{
name: "Fox",
color: "#f49849",
class: "🌲",
rarity: "Common",
cash: [7, 15, 80, 550, 3000],
time: [2, 2, 1, 1, 1],
price: [400, 4000, 36000, 240000]
},
{
name: "Raccoon",
color: "#6d6e71",
class: "🌲",
rarity: "Common",
cash: [5, 14, 185, 1900, 19000],
time: [2, 2, 2, 2, 2],
price: [400, 5000, 71000, 800000]
},
{
name: "Squirrel",
color: "#d25927",
class: "🌲",
rarity: "Common",
cash: [3, 10, 65, 470, 2600],
time: [1, 1, 1, 1, 1],
price: [420, 3600, 32000, 210000]
},
{
name: "Owl",
color: "#594a42",
class: "🌲",
rarity: "Common",
cash: [4, 17, 155, 1500, 15000],
time: [2, 2, 2, 2, 2],
price: [500, 4800, 55000, 580000]
},
{
name: "Hedgehog",
color: "#3f312b",
class: "🌲",
rarity: "Common",
cash: [11, 37, 340, 2200, 30000],
time: [5, 4, 3, 2, 2],
price: [540, 7000, 77000, 1200000]
},
{
name: "Seal",
color: "#7ca1d5",
class: "❄️",
rarity: "Common",
cash: [6, 17, 150, 1200, 13000],
time: [2, 2, 2, 2, 2],
price: [480, 4500, 43000, 520000]
},
{
name: "Arctic Fox",
color: "#7ca1d5",
class: "❄️",
rarity: "Common",
cash: [5, 18, 180, 850, 8500],
time: [2, 2, 2, 1, 1],
price: [520, 550, 61000, 680000]
},
{
name: "Snowy Owl",
color: "#feda3f",
class: "❄️",
rarity: "Common",
cash: [5, 20, 190, 1900, 16000],
time: [3, 3, 2, 2, 2],
price: [370, 5300, 76000, 620000]
},
{
name: "Arctic Hare",
color: "#7ca1d5",
class: "❄️",
rarity: "Common",
cash: [6, 19, 85, 900, 7000],
time: [2, 2, 1, 1, 1],
price: [540, 5200, 66000, 550000]
},
{
name: "Penguin",
color: "#fb8640",
class: "❄️",
rarity: "Common",
cash: [4, 21, 310, 3200, 33000],
time: [3, 3, 3, 3, 3],
price: [400, 6500, 76000, 870000]
},
{
name: "Baby Penguin",
color: "#414042",
class: "❄️",
rarity: "Common",
cash: [3, 8, 70, 450, 2700],
time: [1, 1, 1, 1, 1],
price: [420, 3300, 33000, 230000]
},
{
name: "Polar Bear",
color: "#7ca1d5",
class: "❄️",
rarity: "Common",
cash: [12, 75, 700, 6500, 85000],
time: [8, 7, 6, 5, 5],
price: [630, 7000, 91000, 1400000]
},
{
name: "Walrus",
color: "#7d4f33",
class: "❄️",
rarity: "Common",
cash: [11, 46, 420, 3700, 51000],
time: [5, 5, 4, 4, 4],
price: [550, 6200, 68000, 1000000]
},
{
name: "Tiger",
color: "#f18221",
class: "🌴",
rarity: "Common",
cash: [6, 20, 100, 975, 7500],
time: [3, 3, 1, 1, 1],
price: [390, 6000, 70000, 610000]
},
{
name: "Jaguar",
color: "#fbb040",
class: "🌴",
rarity: "Common",
cash: [8, 28, 230, 1600, 17000],
time: [3, 3, 2, 2, 2],
price: [390, 6000, 70000, 610000]
},
{
name: "Toucan",
color: "#ffca34",
class: "🌴",
rarity: "Common",
cash: [9, 20, 175, 625, 3800],
time: [2, 2, 2, 1, 1],
price: [520, 4800, 42000, 300000]
},
{
name: "Cockatoo",
color: "#7ca1d5",
class: "🌴",
rarity: "Common",
cash: [6, 35, 160, 1700, 18000],
time: [4, 4, 2, 2, 2],
price: [500, 5000, 63000, 700000]
},
{
name: "Macaw",
color: "#00aeef",
class: "🌴",
rarity: "Common",
cash: [3, 8, 85, 850, 8500],
time: [1, 1, 1, 1, 1],
price: [480, 5400, 62000, 630000]
},
{
name: "Parrot",
color: "#ed1c24",
class: "🌴",
rarity: "Common",
cash: [3, 9, 90, 900, 9000],
time: [1, 1, 1, 1, 1],
price: [540, 5700, 65000, 690000]
},
{
name: "Panther",
color: "#2f2c38",
class: "🌴",
rarity: "Common",
cash: [12, 28, 215, 2100, 21000],
time: [5, 3, 2, 2, 2],
price: [530, 6500, 76000, 870000]
},
{
name: "Anaconda",
color: "#8a9143",
class: "🌴",
rarity: "Common",
cash: [3, 15, 85, 1500, 7600],
time: [1, 2, 1, 2, 1],
price: [410, 5100, 58000, 590000]
},
{
name: "Orangutan",
color: "#bc6234",
class: "🌴",
rarity: "Common",
cash: [13, 52, 570, 4300, 70000],
time: [5, 5, 5, 4, 4],
price: [600, 7000, 80000, 1400000]
},
{
name: "Capuchin",
color: "#e0b0a6",
class: "🌴",
rarity: "Common",
cash: [4, 14, 160, 780, 8200],
time: [2, 2, 2, 1, 1],
price: [390, 4700, 57000, 680000]
},
{
name: "Elf",
color: "#a7d054",
class: "⚔️",
rarity: "Uncommon",
cash: [5000, 15000, 150000, 1500000, 10000000],
time: [1, 1, 1, 1, 1],
price: [800000, 9000000, 110000000, 800000000]
},
{
name: "Witch",
color: "#4ab96d",
class: "⚔️",
rarity: "Uncommon",
cash: [18000, 60000, 40000, 4000000, 35000000],
time: [3, 3, 2, 2, 2],
price: [1100000, 12000000, 150000000, 1400000000]
},
{
name: "Wizard",
color: "#5a459c",
class: "⚔️",
rarity: "Uncommon",
cash: [19500, 65000, 440000, 4600000, 4000000],
time: [3, 3, 2, 2, 2],
price: [1300000, 13500000, 160000000, 1600000000]
},
{
name: "Fairy",
color: "#df6d9c",
class: "⚔️",
rarity: "Uncommon",
cash: [18500, 60000, 620000, 4400000, 38000000],
time: [3, 3, 3, 2, 2],
price: [1200000, 12500000, 15000000, 1500000000]
},
{
name: "Slime Monster",
color: "#2fa04a",
class: "⚔️",
rarity: "Uncommon",
cash: [35000, 140000, 1000000, 11000000, 110000000],
time: [5, 5, 4, 4, 4],
price: [1600000, 15000000, 200000000, 2300000000]
},
{
name: "Jester",
color: "#be1e2d",
class: "⚔️",
rarity: "Rare",
cash: [25000, 100000, 680000, 6500000, 32000000],
time: [3, 3, 2, 2, 1],
price: [2000000, 21000000, 230000000, 2600000000]
},
{
name: "Dragon",
color: "#2fa04a",
class: "⚔️",
rarity: "Rare",
cash: [36000, 150000, 1500000, 15000000, 150000000],
time: [4, 4, 4, 4, 4],
price: [2300000, 24000000, 270000000, 3000000000]
},
{
name: "Unicorn",
color: "#f6afce",
class: "⚔️",
rarity: "Epic",
cash: [24000, 150000, 1400000, 7000000, 75000000],
time: [2, 2, 2, 1, 1],
price: [4500000, 45000000, 550000000, 6500000000]
},
{
name: "Queen",
color: "#9e1f63",
class: "⚔️",
rarity: "Rare",
cash: [24000, 95000, 950000, 9700000, 95000000],
time: [3, 3, 3, 3, 3],
price: [1900000, 20000000, 230000000, 2500000000]
},
{
name: "King",
color: "#ee2640",
class: "⚔️",
rarity: "Legendary",
cash: [75000, 400000, 6000000, 90000000, 1250000000],
time: [5, 5, 5, 5, 5],
price: [6000000, 95000000, 1600000000, 25000000000]
},
{
name: "Two of Spades",
color: "#414042",
class: "🃏",
rarity: "Uncommon",
cash: [4500, 14000, 140000, 1400000, 9000000],
time: [1, 1, 1, 1, 1],
price: [770000, 8300000, 98000000, 710000000]
},
{
name: "Eat Me",
color: "#d58c55",
class: "🃏",
rarity: "Uncommon",
cash: [13000, 45000, 450000, 4500000, 50000000],
time: [2, 2, 2, 2, 2],
price: [1300000, 14000000, 160000000, 2000000000]
},
{
name: "Drink Me",
color: "#dd7399",
class: "🃏",
rarity: "Uncommon",
cash: [12000, 40000, 400000, 4000000, 45000000],
time: [2, 2, 2, 2, 2],
price: [1200000, 12000000, 140000000, 1800000000]
},
{
name: "Alice",
color: "#4cc9f5",
class: "🃏",
rarity: "Uncommon",
cash: [13000, 42000, 210000, 2100000, 23000000],
time: [2, 2, 1, 1, 1],
price: [1200000, 13000000, 150000000, 1900000000]
},
{
name: "Queen of Hearts",
color: "#d62027",
class: "🃏",
rarity: "Uncommon",
cash: [23000, 87000, 620000, 7500000, 90000000],
time: [4, 4, 3, 3, 3],
price: [1300000, 13000000, 180000000, 2400000000]
},
{
name: "Dormouse",
color: "#89d6f8",
class: "🃏",
rarity: "Rare",
cash: [17000, 68000, 700000, 3500000, 35000000],
time: [2, 2, 1, 1, 1],
price: [2000000, 22000000, 250000000, 2800000000]
},
{
name: "White Rabbit",
color: "#ffcd05",
class: "🃏",
rarity: "Rare",
cash: [26000, 105000, 11000000, 7700000, 72000000],
time: [3, 3, 3, 2, 2],
price: [2000000, 23000000, 280000000, 2900000000]
},
{
name: "Cheshire Cat",
color: "#dd7399",
class: "🃏",
rarity: "Rare",
cash: [32000, 100000, 900000, 9000000, 60000000],
time: [4, 3, 3, 3, 2],
price: [1800000, 19000000, 220000000, 2400000000]
},
{
name: "Caterpillar",
color: "#00c0f3",
class: "🃏",
rarity: "Epic",
cash: [10000, 70000, 650000, 7500000, 85000000],
time: [1, 1, 1, 1, 1],
price: [4200000, 42000000, 540000000, 6900000000]
},
{
name: "Mad Hatter",
color: "#914f93",
class: "🃏",
rarity: "Epic",
cash: [38000, 250000, 1500000, 14000000, 80000000],
time: [3, 3, 2, 2, 1],
price: [4800000, 48000000, 520000000, 6600000000]
},
{
name: "King of Hearts",
color: "#c62127",
class: "🃏",
rarity: "Legendary",
cash: [80000, 420000, 6800000, 100000000, 1500000000],
time: [5, 5, 5, 5, 5],
price: [7000000, 110000000, 1800000000, 30000000000]
},
{
name: "Earth",
color: "#416eb5",
class: "🚀",
rarity: "Uncommon",
cash: [15000, 45000, 600000, 6500000, 65000000],
time: [3, 3, 3, 3, 3],
price: [1000000, 11000000, 150000000, 1700000000]
},
{
name: "Meteor",
color: "#c68c3c",
class: "🚀",
rarity: "Uncommon",
cash: [23000, 65000, 700000, 4500000, 20000000],
time: [5, 4, 3, 2, 1],
price: [950000, 13000000, 160000000, 1600000000]
},
{
name: "Stars",
color: "#19184d",
class: "🚀",
rarity: "Uncommon",
cash: [10000, 40000, 200000, 2000000, 18000000],
time: [2, 2, 1, 1, 1],
price: [1400000, 14000000, 150000000, 1500000000]
},
{
name: "Alien",
color: "#8dc63f",
class: "🚀",
rarity: "Uncommon",
cash: [30000, 100000, 1000000, 11000000, 85000000],
time: [4, 4, 4, 4, 4],
price: [1500000, 17000000, 190000000, 1700000000]
},
{
name: "Planet",
color: "#9dc6ea",
class: "🚀",
rarity: "Rare",
cash: [25000, 100000, 900000, 9000000, 90000000],
time: [3, 3, 3, 3, 3],
price: [2000000, 21000000, 210000000, 2400000000]
},
{
name: "UFO",
color: "#a15095",
class: "🚀",
rarity: "Rare",
cash: [17000, 70000, 700000, 7000000, 70000000],
time: [2, 2, 2, 2, 2],
price: [2100000, 23000000, 250000000, 2800000000]
},
{
name: "Spaceship",
color: "#ffcb29",
class: "🚀",
rarity: "Epic",
cash: [60000, 320000, 2100000, 15000000, 85000000],
time: [5, 4, 3, 2, 1],
price: [4800000, 46000000, 540000000, 6800000000]
},
{
name: "Astronaut",
color: "#9bd4ee",
class: "🚀",
rarity: "Legendary",
cash: [45000, 260000, 2500000, 38000000, 550000000],
time: [3, 3, 2, 2, 2],
price: [6500000, 100000000, 1700000000, 27000000000]
},
{
name: "Lil Bot",
color: "#3e564a",
class: "🤖",
rarity: "Uncommon",
cash: [4000, 12000, 180000, 1900000, 25000000],
time: [1, 1, 1, 1, 1],
price: [730000, 12000000, 130000000, 1900000000]
},
{
name: "Lovely Bot",
color: "#f179af",
class: "🤖",
rarity: "Uncommon",
cash: [16000, 65000, 650000, 4800000, 42000000],
time: [3, 3, 3, 2, 2],
price: [1300000, 14000000, 170000000, 1600000000]
},
{
name: "Angry Bot",
color: "#f1613a",
class: "🤖",
rarity: "Uncommon",
cash: [22000, 85000, 800000, 6200000, 65000000],
time: [4, 4, 4, 3, 3],
price: [1200000, 13000000, 150000000, 1700000000]
},
{
name: "Happy Bot",
color: "#51ba6b",
class: "🤖",
rarity: "Uncommon",
cash: [11000, 45000, 500000, 2500000, 30000000],
time: [2, 2, 2, 1, 1],
price: [1400000, 15000000, 180000000, 2400000000]
},
{
name: "Watson",
color: "#d69b5a",
class: "🤖",
rarity: "Rare",
cash: [24000, 100000, 1000000, 10000000, 100000000],
time: [3, 3, 3, 3, 3],
price: [2000000, 22000000, 240000000, 2600000000]
},
{
name: "Buddy Bot",
color: "#9dc6ea",
class: "🤖",
rarity: "Rare",
cash: [22000, 95000, 650000, 6500000, 65000000],
time: [3, 3, 2, 2, 2],
price: [1900000, 21000000, 230000000, 2500000000]
},
{
name: "Brainy Bot",
color: "#9ecf7a",
class: "🤖",
rarity: "Epic",
cash: [50000, 250000, 2100000, 21000000, 170000000],
time: [4, 3, 3, 3, 2],
price: [5000000, 46000000, 500000000, 6700000000]
},
{
name: "Mega Bot",
color: "#d71f27",
class: "🤖",
rarity: "Legendary",
cash: [80000, 430000, 4200000, 62000000, 1000000000],
time: [5, 5, 3, 3, 3],
price: [7000000, 120000000, 1900000000, 35000000000]
}
];
let targetObj = null;
function scanDeep(obj, depth = 0) {
if (depth > 8 || targetObj) return;
if (!obj || typeof obj !== 'object') return;
if (obj.factories && Array.isArray(obj.factories)) {
targetObj = obj;
return;
}
if (Array.isArray(obj)) {
obj.forEach(item => scanDeep(item, depth + 1));
} else {
if (obj.props) scanDeep(obj.props, depth + 1);
if (obj.children) scanDeep(obj.children, depth + 1);
if (obj.memoizedProps) scanDeep(obj.memoizedProps, depth + 1);
if (obj.memoizedState) scanDeep(obj.memoizedState, depth + 1);
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
if (targetObj) return;
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) scanDeep(node[k]);
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (targetObj) {
let iframe = document.createElement('iframe');
document.body.append(iframe);
const input = blook.name;
iframe.remove();
if (!input) return;
const chosenBlook = factoryBlooks.find(b => b.name.toLowerCase() === input.toLowerCase());
if (chosenBlook) {
const maxSlots = 10;
const currentLen = targetObj.factories.length;
const newBlook = {
...chosenBlook,
level: 4,
bonus: 1
};
if (currentLen < maxSlots) {
targetObj.factories.push(newBlook);
alert(`✅ Added ${chosenBlook.name}!`);
} else {
targetObj.factories[maxSlots - 1] = newBlook;
alert(`✅ Replaced last slot with ${chosenBlook.name}!`);
}
alert("IMPORTANT: Buy any upgrade or click a blook to see the change!");
} else {
alert("❌ Invalid Blook Name! Check spelling.");
}
} else {
alert("❌ Could not find factories container.");
}
})();
},
},
{
name: "Free Upgrades",
description: "Sets upgrade prices to 0 for all current blooks",
run: function() {
const prices = [0, 0, 0, 0];
let stateNode = getStateNode();
stateNode.setState({
blooks: stateNode.state.blooks.map((blook) => ((blook.price = prices), blook))
});
},
},
{
name: "Max Blooks",
description: "Maxes out all your blooks' levels",
run: function() {
(() => {
console.clear();
console.log("💉 Factory: Maxing Levels...");
let foundFactories = null;
function scanDeep(obj, depth = 0) {
if (depth > 8 || foundFactories) return;
if (!obj || typeof obj !== 'object') return;
if (obj.factories && Array.isArray(obj.factories) && obj.factories.length > 0) {
const sample = obj.factories[0];
if (sample.cash && sample.level !== undefined) {
foundFactories = obj.factories;
return;
}
}
if (Array.isArray(obj)) {
obj.forEach(item => scanDeep(item, depth + 1));
} else {
if (obj.props) scanDeep(obj.props, depth + 1);
if (obj.children) scanDeep(obj.children, depth + 1);
if (obj.memoizedProps) scanDeep(obj.memoizedProps, depth + 1);
if (obj.memoizedState) scanDeep(obj.memoizedState, depth + 1);
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
if (foundFactories) return;
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) scanDeep(node[k]);
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (foundFactories) {
let count = 0;
foundFactories.forEach(factory => {
factory.level = 4;
count++;
});
let iframe = document.createElement('iframe');
document.body.append(iframe);
iframe.contentWindow.alert(`✅ Set ${count} blooks to Level 4!\n\nIMPORTANT: Perform any action (buy/upgrade) to see the visual change.`);
iframe.remove();
} else {
alert("❌ Could not find factories. Make sure you have at least one blook!");
}
})();
},
},
{
name: "Make Blooks OP",
description: "Make all your blooks OP",
run: function() {
(() => {
console.clear();
console.log("💉 Factory: Making Blooks OP...");
let foundFactories = null;
function scanDeep(obj, depth = 0) {
if (depth > 8 || foundFactories) return;
if (!obj || typeof obj !== 'object') return;
if (obj.factories && Array.isArray(obj.factories) && obj.factories.length > 0) {
const sample = obj.factories[0];
if (sample.cash && Array.isArray(sample.cash) && sample.name) {
foundFactories = obj.factories;
return;
}
}
if (Array.isArray(obj)) {
obj.forEach(item => scanDeep(item, depth + 1));
} else {
if (obj.props) scanDeep(obj.props, depth + 1);
if (obj.children) scanDeep(obj.children, depth + 1);
if (obj.memoizedProps) scanDeep(obj.memoizedProps, depth + 1);
if (obj.memoizedState) scanDeep(obj.memoizedState, depth + 1);
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
if (foundFactories) return;
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) {
scanDeep(node[k]);
}
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (foundFactories) {
let count = 0;
foundFactories.forEach(factory => {
factory.cash = [1e9, 1e9, 1e9, 1e9, 1e9];
factory.time = [0.01, 0.01, 0.01, 0.01, 0.01];
count++;
});
let iframe = document.createElement('iframe');
document.body.append(iframe);
iframe.contentWindow.alert(`✅ Made ${count} blooks OP!\n\nIMPORTANT: Buy an upgrade or a new blook to force the stats to update.`);
iframe.remove();
} else {
alert("❌ Could not find factories. Make sure you have at least one blook!");
}
})();
}
},
{
name: "Remove Glitches",
description: "Removes all enemy glitches",
run: function() {
(() => {
console.clear();
console.log("🛡️ HUNTING GLITCH STRINGS IN MEMORY...");
const glitchNames = [
"Lunch Break", "Ad Spam", "Error 37", "Night Time", "#LOL",
"Jokester", "Slow Mo", "Dance Party", "Vortex", "Reverse", "Flip", "Micro"
];
let foundCount = 0;
let visited = new Set();
function clearState(obj, key) {
console.log(`%c🔥 FOUND GLITCH: "${obj[key]}" in key "${key}"`, "color: red; font-weight: bold;");
console.log(" Object:", obj);
obj[key] = "";
if (Array.isArray(obj.ads)) obj.ads = [];
if (Array.isArray(obj.hazards)) obj.hazards = [];
if (typeof obj.lol === 'boolean') obj.lol = false;
if (typeof obj.night === 'boolean') obj.night = false;
if (typeof obj.joke === 'boolean') obj.joke = false;
if (typeof obj.slow === 'boolean') obj.slow = false;
if (typeof obj.dance === 'boolean') obj.dance = false;
if (typeof obj.color === 'string') obj.color = "";
foundCount++;
}
function scanDeep(obj, depth = 0) {
if (!obj || typeof obj !== 'object' || depth > 10) return;
if (visited.has(obj)) return;
visited.add(obj);
for (const key in obj) {
const val = obj[key];
if (typeof val === 'string') {
for (const gName of glitchNames) {
if (val === gName) {
clearState(obj, key);
}
}
}
if (key.startsWith('_') && key !== '_owner') continue;
if (typeof val === 'object') {
scanDeep(val, depth + 1);
}
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) {
const fiber = node[k];
if (fiber.memoizedState) scanDeep(fiber.memoizedState);
if (fiber.memoizedProps) scanDeep(fiber.memoizedProps);
}
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (foundCount > 0) {
let iframe = document.createElement('iframe');
document.body.append(iframe);
iframe.contentWindow.alert(`✅ Found and cleared ${foundCount} glitch objects in memory!`);
iframe.remove();
} else {
alert("❌ No active glitch strings found in memory. \n(Wait until you actually have a glitch active, then run this!)");
}
})();
},
},
{
name: "Set All MegaBot",
description: "Sets all your blooks to maxed out Mega Bots",
run: function() {
(() => {
console.clear();
console.log("🏭 Factory: Setting all to Mega Bots...");
let targetObj = null;
function scanDeep(obj, depth = 0) {
if (depth > 8 || targetObj) return;
if (!obj || typeof obj !== 'object') return;
if (obj.factories && Array.isArray(obj.factories)) {
targetObj = obj;
return;
}
if (Array.isArray(obj)) {
obj.forEach(item => scanDeep(item, depth + 1));
} else {
if (obj.props) scanDeep(obj.props, depth + 1);
if (obj.children) scanDeep(obj.children, depth + 1);
if (obj.memoizedProps) scanDeep(obj.memoizedProps, depth + 1);
if (obj.memoizedState) scanDeep(obj.memoizedState, depth + 1);
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
if (targetObj) return;
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) scanDeep(node[k]);
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (targetObj) {
const megaBot = {
name: "Mega Bot",
color: "#d71f27",
class: "🤖",
rarity: "Legendary",
cash: [80000, 430000, 4200000, 62000000, 1000000000],
time: [5, 5, 3, 3, 3],
price: [7000000, 120000000, 1900000000, 35000000000],
active: false,
level: 4,
bonus: 5.0
};
const arr = targetObj.factories;
arr.length = 0;
for (let i = 0; i < 10; i++) {
arr.push({
...megaBot
});
}
let iframe = document.createElement('iframe');
document.body.append(iframe);
iframe.contentWindow.alert("✅ Factory replaced with 10 Mega Bots!\n\nIMPORTANT: Buy an upgrade or click a blook to refresh the visuals.");
iframe.remove();
} else {
alert("❌ Could not find factories container. Place at least one blook first.");
}
})();
},
},
{
name: "Set Cash",
description: "Sets amount of cash you have",
inputs: [{
name: "Cash",
type: "number",
}, ],
run: function(cash) {
(() => {
console.clear();
console.log("🏦 Factory: Setting Exact Cash...");
let gameState = null;
function scanDeep(obj, depth = 0) {
if (depth > 8 || gameState) return;
if (!obj || typeof obj !== 'object') return;
if (obj.factories && typeof obj.addCash === 'function' && obj.cash !== undefined) {
gameState = obj;
return;
}
if (Array.isArray(obj)) {
obj.forEach(item => scanDeep(item, depth + 1));
} else {
if (obj.props) scanDeep(obj.props, depth + 1);
if (obj.children) scanDeep(obj.children, depth + 1);
if (obj.memoizedProps) scanDeep(obj.memoizedProps, depth + 1);
if (obj.memoizedState) scanDeep(obj.memoizedState, depth + 1);
}
}
const root = document.querySelector('#app') || document.body;
function traverseDOM(node) {
if (gameState) return;
const k = Object.keys(node).find(key => key.startsWith('__reactFiber'));
if (k) scanDeep(node[k]);
for (const child of node.children) traverseDOM(child);
}
traverseDOM(root);
if (gameState) {
const current = gameState.cash;
let iframe = document.createElement('iframe');
document.body.append(iframe);
const input = cash;
iframe.remove();
if (input !== null) {
const target = parseFloat(input);
if (!isNaN(target)) {
const diff = target - gameState.cash;
gameState.addCash(diff);
alert(`✅ Cash set to ${target}!`);
}
}
} else {
alert("❌ Could not find Game Controller.");
}
})();
},
},
],
},
racing: {
// img: "https://media.blooket.com/image/upload/v1663212882/Media/logos/Racing_Logo_Resized.png",
img: "",
name: "Racing",
cheats: [{
name: "Instant Win",
description: "Instantly Wins the race",
run: function() {
const stateNode = getStateNode();
stateNode.setState({
progress: stateNode.state.goalAmount
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/pr",
val: stateNode.state.goalAmount,
});
},
},
{
name: "Set Questions",
description: "Sets the number of questions left",
inputs: [{
name: "Questions",
type: "number",
}, ],
run: function(progress) {
let stateNode = getStateNode();
progress = stateNode.props.client.amount - progress;
stateNode.setState({
progress
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/pr",
val: progress,
});
},
},
],
},
rush: {
// img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Blook_Rush_Logo_Resized.png",
img: "",
name: "Blook Rush",
cheats: [{
name: "Set Blooks",
description: "Sets amount of blooks you or your team has",
inputs: [{
name: "Blooks",
type: "number",
}, ],
run: function(numBlooks) {
let stateNode = getStateNode();
stateNode.setState({
numBlooks
});
stateNode.props.liveGameController.setVal({
path: (stateNode.isTeam ? "a/" : "c/") + stateNode.props.client.name + "/bs",
val: numBlooks,
});
},
},
{
name: "Set Defense",
description: "Sets amount of defense you or your team has (Max 4)",
inputs: [{
name: "Defense (max 4)",
type: "number",
max: 4,
}, ],
run: function(defense) {
let numDefense = Math.min(defense, 4);
let stateNode = getStateNode();
stateNode.setState({
numDefense
});
stateNode.props.liveGameController.setVal({
path: (stateNode.isTeam ? "a/" : "c/") + stateNode.props.client.name + "/d",
val: numDefense,
});
},
},
],
},
tower: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Tower_Of_Doom_Logo_Resized.png",
name: "Tower of Doom",
cheats: [{
name: "Fill Deck",
description: "Fills your deck with every maxed out card and artifact (Only works on towers page)",
run: function() {
if (window.location.pathname == "/tower/map") {
const stateNode = getStateNode();
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(
"|"
);
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) => {
const [blook, c] = x.split(",");
return {
strength: 20,
charisma: 20,
wisdom: 20,
class: c,
blook
};
});
try {
stateNode.props.addTowerNode();
} catch {}
stateNode.setState({
showDeck: false
});
} else alert("You need to be on the map to run this cheat!");
},
},
{
name: "Max Cards",
description: "Maxes out all the cards in your deck",
run: function() {
if (window.location.pathname == "/tower/map") {
const stateNode = getStateNode();
stateNode.props.tower.cards.forEach((card) => {
card.strength = 20;
card.charisma = 20;
card.wisdom = 20;
});
try {
stateNode.forceUpdate();
} catch {}
} else alert("You need to be on the map to run this cheat!");
},
},
{
name: "Max Health",
description: "Fills the player's health",
run: function() {
if (window.location.pathname == "/tower/battle") getStateNode().setState({
myHealth: 100,
myLife: 100
});
else alert("You need to be in battle to run this cheat!");
},
},
{
name: "Max Card Stats",
description: "Maxes out player's current card (Only works on attribute select page)",
run: function() {
const stateNode = getStateNode();
if (stateNode.state.phase !== "select") alert("You must be on the attribute selection page!");
else stateNode.setState({
myCard: {
...stateNode.state.myCard,
strength: 20,
charisma: 20,
wisdom: 20
}
});
},
},
{
name: "Min Enemy Stats",
description: "Makes the enemy card stats all 0 (Only works on attribute select page)",
run: function() {
const stateNode = getStateNode();
if (stateNode.state.phase !== "select") alert("You must be on the attribute selection page!");
else stateNode.setState({
enemyCard: {
...stateNode.state.enemyCard,
strength: 0,
charisma: 0,
wisdom: 0
}
});
},
},
{
name: "Set Coins",
description: "Try's to set amount of tower coins you have",
inputs: [{
name: "Coins",
type: "number",
}, ],
run: function(coins) {
if (window.location.pathname == "/tower/battle")
try {
getStateNode().props.setTowerCoins(coins);
} catch {}
else alert("You need to be in battle to run this cheat!");
},
},
],
},
kingdom: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Crazy_Kingdom_Logo_Resized.png",
name: "Crazy Kingdom",
cheats: [{
name: "Choice ESP",
description: "Shows you what will happen if you say Yes or No",
type: "toggle",
enabled: false,
data: null,
run: function() {
if (!this.enabled) {
this.enabled = true;
this.data = setInterval(
(stats) => {
let stateNode = getStateNode();
let elements = Array.prototype.reduce.call(document.querySelectorAll("[class*=statContainer]"), (obj, container, i) => ((obj[stats[i]] = container), obj), {});
if (stateNode.state.phase == "choice") {
Array.prototype.forEach.call(document.querySelectorAll(".choiceESP"), (x) => x.remove());
Object.keys(stateNode.state.guest.yes || {}).forEach((x) => {
if (elements[x] == null) return;
let element = document.createElement("div");
element.className = "choiceESP";
element.style = "font-size: 24px; color: rgb(75, 194, 46); font-weight: bolder;";
element.innerText = String(stateNode.state.guest.yes[x]);
elements[x].appendChild(element);
});
Object.keys(stateNode.state.guest.no || {}).forEach((x) => {
if (elements[x] == null) return;
let element = document.createElement("div");
element.className = "choiceESP";
element.style = "font-size: 24px; color: darkred; font-weight: bolder;";
element.innerText = String(stateNode.state.guest.no[x]);
elements[x].appendChild(element);
});
Array.prototype.forEach.call(
document.querySelectorAll("[class*=guestButton][role=button]"),
(x) => (x.onclick = () => Array.prototype.forEach.call(document.querySelectorAll(".choiceESP"), (x) => x.remove()))
);
}
},
50,
["materials", "people", "happiness", "gold"]
);
} else {
this.enabled = false;
clearInterval(this.data);
Array.prototype.forEach.call(document.querySelectorAll(".choiceESP"), (x) => x.remove());
this.data = null;
}
},
},
{
name: "Disable Tax Toucan",
description: "Tax evasion",
run: function() {
getStateNode().taxCounter = Number.MAX_VALUE;
},
},
{
name: "Max Stats",
description: "Sets all resources to the max",
run: function() {
getStateNode().setState({
materials: 100,
people: 100,
happiness: 100,
gold: 100
});
},
},
{
name: "Set Guests",
description: "Sets the amount of guests you've seen",
inputs: [{
name: "Guests",
type: "number",
}, ],
run: function(guestScore) {
getStateNode().setState({
guestScore
});
},
},
{
name: "Skip Guest",
description: "Skips the current guest",
run: function() {
getStateNode().nextGuest();
},
},
],
},
toy: {
img: "https://media.blooket.com/image/upload/v1663212881/Media/logos/Santas_Workshop_Logo_Resized.png",
name: "Santa's Workshop",
cheats: [{
name: "Remove Distractions",
description: "Removes all enemy distractions",
run: function() {
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]
});
},
},
{
name: "Send Distraction",
description: "Sends a distraction to everyone else playing",
inputs: [{
name: "Distraction",
type: "options",
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,
})),
}, ],
run: function(val) {
let stateNode = getStateNode();
stateNode.safe = true;
stateNode.props.liveGameController.setVal({
path: `c/${stateNode.props.client.name}/tat`,
val
});
},
},
{
name: "Set Toys",
description: "Sets amount of toys",
inputs: [{
name: "Toys",
type: "number",
}, ],
run: function(toys) {
let stateNode = getStateNode();
stateNode.setState({
toys
});
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/t",
val: toys,
});
},
},
{
name: "Set Toys Per Question",
description: "Sets amount of toys per question",
inputs: [{
name: "Toys Per Question",
type: "number",
}, ],
run: function(toysPerQ) {
getStateNode().setState({
toysPerQ
});
},
},
{
name: "Swap Toys",
description: "Swaps toys with someone",
inputs: [{
name: "Player",
type: "options",
options: () => {
let stateNode = getStateNode();
return stateNode.props.liveGameController._liveApp ? new Promise((res) => stateNode.props.liveGameController.getDatabaseVal("c", (players) => players && res(Object.keys(players)))) : [];
},
}, ],
run: function(target) {
let stateNode = getStateNode();
stateNode.props.liveGameController.getDatabaseVal("c", (players) => {
if (!players || players[target] == null) return;
stateNode.props.liveGameController.setVal({
path: "c/" + stateNode.props.client.name + "/tat",
val: `${target}:swap:${stateNode.state.toys}`,
});
stateNode.setState({
toys: players[target].t
});
});
},
},
],
},
flappy: {
img: "https://ac.blooket.com/marketassets/blooks/chick.svg",
name: "Flappy Blook",
cheats: [{
name: "Toggle Ghost",
description: "Lets you go through the pipes",
type: "toggle",
enabled: false,
run: function() {
this.enabled = !this.enabled;
for (const body of Object.values(document.querySelector("#phaser-bouncy"))[0].return.updateQueue.lastEffect.deps[0].current.config.sceneConfig.physics.world.bodies.entries) {
if (!body.gameObject.frame.texture.key.startsWith("blook")) continue;
body.checkCollision.none = this.enabled;
body.gameObject.setAlpha(this.enabled ? 0.5 : 1);
break;
}
},
},
{
name: "Change Settings",
description: "Changes various game mechanics and lets you play with the spacebar",
inputs: [{
name: "Bird Gravity",
type: "number",
value: 800
},
{
name: "Bird Speed",
type: "number",
value: 125
},
{
name: "Bird Flap Power",
type: "number",
value: 300
}
],
run: function(birdGravity, birdSpeed, birdFlapPower) {
(function() {
const canvas = document.querySelector("#phaser-bouncy");
if (!canvas) return;
const scene = Object.values(canvas)[0].return.updateQueue.lastEffect.deps[0].current.config.sceneConfig;
if (!scene) return;
// Apply custom settings
scene.birdGravity = birdGravity;
scene.birdSpeed = birdSpeed;
scene.birdFlapPower = birdFlapPower;
// Override flap function
scene.flap = function() {
if (!this.isStarted) {
this.bird.body.gravity.y = this.birdGravity;
this.pipeGroup.setVelocityX(-this.birdSpeed);
this.groundGroup.setVelocityX(-this.birdSpeed);
this.isStarted = true;
}
this.bird.body.velocity.y = -this.birdFlapPower;
};
// Clear previous pointer events
scene.input._events.pointerdown = [];
// Recreate the scene
scene.create();
// Add spacebar flap
scene.input.keyboard.addKey('SPACE').on("down", () => {
scene.flap.call(scene);
});
})();
}
},
{
name: "Change Game Code",
description: "Replace the old game with new HTML content",
inputs: [{
name: "HTML Code",
type: "text"
}],
run: function(newHtml) {
(function() {
if (newHtml) {
var canvas = document.querySelector('canvas[width="320"][height="480"]');
if (canvas) {
var tempContainer = document.createElement('div');
tempContainer.innerHTML = newHtml;
var wrapperDiv = document.createElement('div');
wrapperDiv.style.width = '320px';
wrapperDiv.style.height = '480px';
wrapperDiv.style.overflow = 'auto';
wrapperDiv.style.boxSizing = 'border-box';
wrapperDiv.style.position = canvas.style.position;
wrapperDiv.style.marginLeft = canvas.style.marginLeft;
wrapperDiv.style.marginTop = canvas.style.marginTop;
wrapperDiv.style.cursor = canvas.style.cursor;
wrapperDiv.style.backgroundColor = '#f0f0f0';
while (tempContainer.firstChild) {
wrapperDiv.appendChild(tempContainer.firstChild);
}
canvas.parentNode.replaceChild(wrapperDiv, canvas);
}
var scoreTextDiv = document.querySelector('div._scoreText_e2c5l_7');
if (scoreTextDiv) {
scoreTextDiv.parentNode.removeChild(scoreTextDiv);
}
}
})();
}
}, {
name: "Set Score",
description: "Sets flappy blook score",
inputs: [{
name: "Score",
type: "number",
}, ],
run: function(score) {
Object.values(document.querySelector("#phaser-bouncy"))[0].return.updateQueue.lastEffect.deps[1](score || 0);
},
},
],
},
};
const searchPage = document.createElement("div");
searchPage.className = classes.searchPage;
const searchbarHolder = document.createElement("form");
searchbarHolder.className = classes.searchbarHolder;
const searchbarInput = document.createElement("input");
searchbarInput.placeholder = "Search Cheats";
searchbarInput.className = classes.searchbarInput;
const searchbarButton = document.createElement("div");
searchbarButton.onclick = () => (searchbarInput.value = "");
searchbarButton.innerHTML = '<i class="fas fa-times" style="line-height: 1;"></i>';
searchbarButton.className = classes.searchbarButton;
searchbarHolder.append(searchbarInput, searchbarButton);
const searchResults = document.createElement("div");
searchResults.className = classes.noScroll + " " + classes.searchResults;
const noResult = document.createElement("div");
noResult.className = classes.noResult;
searchPage.append(searchbarHolder, searchResults);
let searchThrottle,
gamemodeResults = {};
searchPage.onPath = searchbarHolder.onsubmit = (e) => {
clearTimeout(searchThrottle);
e?.preventDefault?.();
const query = searchbarInput.value.toLowerCase();
let hasResults = false;
const animEnabled = window.xguiAnimationsEnabled;
for (const child of searchResults.children) {
if (child != noResult) {
if (child.dataset[datasets.mode]?.includes?.(query) || child.dataset[datasets.name].includes(query) || child.dataset[datasets.description]?.includes?.(query)) {
hasResults = true;
// Add smooth slide-in animation if enabled
if (animEnabled) {
child.style.animation = "slideInLeft 0.3s ease-out";
}
child.style.display = "block";
if (child.dataset[datasets.mode]) {
if (animEnabled) {
gamemodeResults[child.dataset[datasets.mode]].style.animation = "slideInLeft 0.3s ease-out";
}
gamemodeResults[child.dataset[datasets.mode]].style.display = "block";
}
} else {
// Add smooth slide-out animation if enabled
if (animEnabled) {
child.style.animation = "slideOutRight 0.3s ease-out";
setTimeout(() => {
child.style.display = "none";
}, 300);
} else {
child.style.display = "none";
}
}
}
}
if (!hasResults) {
noResult.innerText = `No results found for "${query}"`;
if (animEnabled) {
noResult.style.animation = "fadeIn 0.3s ease-out";
}
noResult.style.display = "block";
} else {
if (animEnabled) {
noResult.style.animation = "fadeOut 0.3s ease-out";
setTimeout(() => {
noResult.style.display = "none";
}, 300);
} else {
noResult.style.display = "none";
}
}
};
searchbarInput.oninput = (e) => {
clearTimeout(searchThrottle);
searchThrottle = setTimeout(searchbarHolder.onsubmit, 100); // Reduced from 1000ms to 100ms for instant search
};
const favoritesPage = document.createElement("div");
favoritesPage.className = classes.noScroll + " " + classes.favoritesPage;
const noFavorites = document.createElement("span");
noFavorites.innerText = "You have no favorites.";
favoritesPage.append(noFavorites);
favoritesPage.onPath = () => {
noFavorites.style.display = favoritesPage.querySelector("[data-" + datasets.favorited + "='true']") == null ? "block" : "none";
};
gamemodesList.innerHTML = "";
searchResults.innerHTML = "";
searchResults.append(noResult);
for (const mode in cheats) {
const gamemode = document.createElement("div");
gamemode.className = classes.gamemode;
const image = document.createElement("img");
image.src = cheats[mode].img;
const name = document.createElement("div");
image.alt = name.innerText = cheats[mode].name;
gamemode.append(image, name);
const cheatsPage = document.createElement("div");
cheatsPage.className = classes.contentPage;
if (mode === 'custom_modules') {
cheatsPage.dataset.customModulesPage = 'true';
customModulesPageRef = cheatsPage;
}
const cheatsList = document.createElement("div");
cheatsList.className = classes.cheatsList + " " + classes.noScroll;
if (mode === 'custom_modules') {
customModulesCheatsList = cheatsList;
}
const inputElements = [];
cheatsPage.onPath = () => inputElements.forEach((x) => x());
const searchResultSeparator = document.createElement("div");
searchResultSeparator.onclick = () => path.push(cheats[mode].name, cheatsPage);
searchResultSeparator.className = classes.searchResultSeparator;
searchResultSeparator.dataset[datasets.name] = (searchResultSeparator.innerText = cheats[mode].name).toLowerCase();
gamemodeResults[cheats[mode].name.toLowerCase()] = searchResultSeparator;
searchResults.append(searchResultSeparator);
const favoritesSeparator = searchResultSeparator.cloneNode(true);
favoritesSeparator.dataset[datasets.favorites] = 0;
favoritesSeparator.onclick = searchResultSeparator.onclick;
favoritesPage.append(favoritesSeparator);
for (const cheat of cheats[mode].cheats) {
const cheatId = `${mode}.${cheat.name.toLowerCase()}.${cheat.type == "toggle" ? "toggle" : "execute"}`;
const cheatElement = document.createElement("div");
const searchResult = document.createElement("div");
searchResult.className = classes.searchResult;
const searchResultInfo = document.createElement("div");
searchResultInfo.className = classes.searchResultInfo;
const searchResultName = document.createElement("div");
searchResultName.className = classes.searchResultName;
searchResult.dataset[datasets.name] = (searchResultName.innerText = cheat.name + (cheat.type == "toggle" && !cheat.name.includes("toggle") ? " (Toggle)" : "")).toLowerCase();
searchResult.dataset[datasets.mode] = cheats[mode].name.toLowerCase();
const searchResultDescription = document.createElement("div");
searchResultDescription.className = classes.searchResultDescription;
searchResult.dataset[datasets.description] = (searchResultDescription.innerText = cheat.description).toLowerCase();
searchResultInfo.append(searchResultName, searchResultDescription);
searchResult.onclick = () => {
path.push(searchResultName.innerText, cheatsPage);
cheatElement.scrollIntoView();
cheatElement.animate(
[{
color: "var(--textColor)",
textShadow: "0 0 0px var(--highlight)",
},
{
color: "var(--highlight)",
textShadow: "0 0 5px var(--highlight)",
offset: 0.25,
},
{
color: "var(--textColor)",
textShadow: "0 0 0px var(--highlight)",
},
],
1500
);
};
searchResult.append(searchResultInfo);
searchResults.append(searchResult);
const cheatTop = document.createElement("div");
cheatTop.className = classes.cheatTop;
const cheatInfo = document.createElement("div");
cheatInfo.className = classes.cheatInfo;
const cheatName = document.createElement("span");
cheatName.innerText = cheat.name;
cheatName.className = classes.cheatName;
const favoriteButton = document.createElement("i");
favoriteButton.className = "far fa-star " + classes.favoriteButton;
const favoriteInner = document.createElement("i");
favoriteInner.className = "fas fa-star";
favoriteButton.append(favoriteInner);
let favoritesPageCopy = searchResult.cloneNode(true);
favoritesPageCopy.dataset[datasets.favorited] = false;
favoritesPageCopy.onclick = searchResult.onclick;
favoritesPage.append(favoritesPageCopy);
favoriteButton.onclick = () => {
const favorited = cheatId in Settings.data.favorites;
favoriteInner.classList.toggle(classes.filled, !favorited);
if (favorited) {
delete Settings.data.favorites[cheatId];
favoritesPageCopy.dataset[datasets.favorited] = false;
favoritesSeparator.dataset[datasets.favorites]--;
} else {
Settings.data.favorites[cheatId] = 1;
favoritesPageCopy.dataset[datasets.favorited] = true;
favoritesSeparator.dataset[datasets.favorites]++;
}
favoritesPage.onPath();
Settings.setData(Settings.data);
};
if (cheatId in (Settings.data.favorites ??= {})) {
favoriteInner.classList.toggle(classes.filled, true);
favoritesPageCopy.dataset[datasets.favorited] = true;
favoritesSeparator.dataset[datasets.favorites]++;
}
cheatName.append(favoriteButton);
const cheatDescription = document.createElement("span");
cheatDescription.innerText = cheat.description;
cheatDescription.className = classes.cheatDescription;
cheatInfo.append(cheatName, cheatDescription);
cheatElement.append(cheatTop);
const inputs = [];
if (Array.isArray(cheat.inputs)) {
const cheatInputs = document.createElement("div");
cheatInputs.className = classes.cheatInputs;
for (const input of cheat.inputs) {
const inputElement = document.createElement("div");
const inputName = document.createElement("span");
inputName.innerText = input.name;
inputElement.append(inputName);
cheatInputs.append(inputElement);
if (input.type == "options") {
const inputField = document.createElement("select");
inputField.dataset[datasets.type] = "options";
inputElement.append(inputField);
inputs.push(inputField);
let curField = inputField;
const updateOptions = () => {
let choose = input.options;
const newInputField = document.createElement("select");
newInputField.dataset[datasets.type] = "options";
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
curField = newInputField;
if (typeof choose == "function")
try {
choose = choose();
} catch {
choose = [];
}
if (choose instanceof Promise) {
const waiting = document.createElement("option");
waiting.value = '""';
waiting.innerHTML = "Loading Options...";
curField.append(waiting);
choose.then((choices) => {
if (choices?.length > 0) {
curField.innerHTML = "";
for (const choice of choices) {
const option = document.createElement("option");
option.value = JSON.stringify(choice?.value ?? choice);
option.innerHTML = choice?.name || choice;
curField.append(option);
}
} else {
const newInputField = document.createElement("input");
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
newInputField.dataset[datasets.type] = "string";
newInputField.placeholder = input.name;
curField = newInputField;
}
});
} else {
if (choose?.length > 0) {
for (const choice of choose) {
const option = document.createElement("option");
option.value = JSON.stringify(choice?.value ?? choice);
option.innerHTML = choice?.name || choice;
curField.append(option);
}
} else {
const newInputField = document.createElement("input");
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
newInputField.dataset[datasets.type] = "string";
newInputField.placeholder = input.name;
curField = newInputField;
}
}
};
updateOptions();
inputElements.push(updateOptions);
} else {
const inputField = document.createElement("input");
inputField.dataset[datasets.type] = input.type;
if (input.type == "number") {
inputField.type = "number";
inputField.min = input.min;
inputField.max = input.max;
inputField.value = input.value || (input.min ?? 0);
}
inputField.placeholder = input.name;
inputElement.append(inputField);
inputs.push(inputField);
}
}
cheatElement.append(cheatInputs);
}
cheatTop.append(cheatInfo);
const runButton = document.createElement("div");
runButton.className = classes.runCheat;
if (cheat.type == "toggle") {
runButton.innerText = "Toggle On";
runButton.classList.add(classes.toggleCheat);
} else runButton.innerText = "Execute";
runButton.onclick = () => {
try {
cheat.run.apply(
cheat,
inputs.map((x) => (x.dataset[datasets.type] == "number" ? parseFloat("0" + x.value) : x.dataset[datasets.type] == "options" ? JSON.parse(x.value) : x.value))
);
if (cheat.type == "toggle") {
runButton.innerText = "Toggle " + (cheat.enabled ? "Off" : "On");
runButton.classList.toggle(classes.active, cheat.enabled);
Logs.addLog(`Toggled "${cheat.name}" ${cheat.enabled ? "on" : "off"}`, cheat.enabled ? "var(--toggleOn)" : "var(--toggleOff)");
if (areSweetAlertsEnabled()) {
Swal.fire({title:'Cheat Toggled',text:`${cheat.name} is now ${cheat.enabled?'Enabled':'Disabled'}.`,icon:cheat.enabled?'success':'warning',toast:true,position:'bottom',timer:3000,timerProgressBar:true,showConfirmButton:false,background:'#151534',color:'#ffffff',iconColor:'#ffffff'});
}
} else {
Logs.addLog(`Ran "${cheat.name}"`, "var(--highlight)");
if (areSweetAlertsEnabled()) {
Swal.fire({title:'Cheat Executed',text:`${cheat.name} has been Executed.`,icon:'info',toast:true,position:'bottom',timer:3000,timerProgressBar:true,showConfirmButton:false,background:'#151534',color:'#ffffff',iconColor:'#ffffff'});
}
}
} catch (err) {
Logs.addLog(`Error running "${cheat.name}": ${err.message}`, "var(--error)");
if (areSweetAlertsEnabled()) {
Swal.fire({title:'Cheat Error',text:`An error occurred while running ${cheat.name} make sure you are on the right page!`,icon:'error',toast:true,position:'bottom',timer:3000,timerProgressBar:true,showConfirmButton:false,background:'#151534',color:'#ffffff',iconColor:'#ff0000'});
}
}
};
cheatTop.append(runButton);
cheatsList.append(cheatElement);
}
cheatsPage.append(cheatsList);
gamemode.onclick = () => {
const unsupportedModes = ["racing", "royale", "dino", "rush"]; // <-- Unsuported Gamemodes go here
// Check for CSP on custom_modules gamemode
if (mode === "custom_modules") {
let cspDetected = false;
try {
const testScript = document.createElement('script');
testScript.textContent = 'window.__cspTestPassed2 = true;';
document.head.appendChild(testScript);
document.head.removeChild(testScript);
if (!window.__cspTestPassed2) {
cspDetected = true;
}
delete window.__cspTestPassed2;
} catch (e) {
cspDetected = true;
}
const cspMeta = document.querySelector('meta[http-equiv="Content-Security-Policy"]');
if (cspMeta && cspMeta.content.includes('script-src')) {
cspDetected = true;
}
if (cspDetected) {
path.push(cheats[mode].name, cheatsPage);
try {
if (cheatsPage && cheatsPage.style) {
let blurTarget = cheatsPage.querySelector && cheatsPage.querySelector('.xgui-blur-target');
if (!blurTarget) {
blurTarget = document.createElement('div');
blurTarget.className = 'xgui-blur-target';
while (cheatsPage.firstChild) {
blurTarget.appendChild(cheatsPage.firstChild);
}
cheatsPage.appendChild(blurTarget);
}
blurTarget.style.filter = 'blur(8px)';
blurTarget.style.pointerEvents = 'none';
}
} catch (e) {}
if (cheatsPage.querySelector && cheatsPage.querySelector('.xgui-csp-notice')) return;
const notice = document.createElement("div");
notice.className = 'xgui-csp-notice';
try {
if (!cheatsPage.style.position || cheatsPage.style.position === 'static') cheatsPage.style.position = 'relative';
// Allow content to extend beyond the cheatsPage bounds
cheatsPage.style.overflow = 'visible';
} catch (e) {}
notice.style.cssText = `
position: absolute;
inset: 0;
display: flex !important;
align-items: flex-start !important;
justify-content: center !important;
z-index: 2000;
pointer-events: auto;
text-align: center;
background: transparent;
padding: 20px;
overflow: visible !important;
`;
const content = document.createElement('div');
content.className = 'xgui-csp-notice-content';
content.style.cssText = `
box-sizing: border-box !important;
display: block !important;
max-width: 380px !important;
width: 100% !important;
padding: 40px 35px !important;
border-radius: 20px !important;
backdrop-filter: blur(24px) saturate(180%) !important;
-webkit-backdrop-filter: blur(24px) saturate(180%) !important;
background: linear-gradient(145deg, rgba(138, 43, 226, 0.15), rgba(75, 0, 130, 0.1)) !important;
border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
box-shadow:
0 10px 40px rgba(0, 0, 0, 0.5),
0 0 0 1px rgba(255, 255, 255, 0.08) inset,
0 25px 70px rgba(138, 43, 226, 0.2) !important;
text-align: center !important;
margin-top: -40px !important;
`;
const iconWrapper = document.createElement("div");
iconWrapper.innerHTML = `
<svg width="64" height="64" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M12 2L4 6V11C4 16 7 20 12 22C17 20 20 16 20 11V6L12 2Z" stroke="currentColor" stroke-width="2" stroke-linejoin="round"/>
<path d="M9 9L15 15M15 9L9 15" stroke="currentColor" stroke-width="2" stroke-linecap="round"/>
</svg>
`;
iconWrapper.style.cssText = `
display: block !important;
color: #FFFFFF !important;
margin: 0 auto 20px auto !important;
padding: 0 !important;
line-height: 1 !important;
filter: drop-shadow(0 4px 16px rgba(255, 255, 255, 0.3)) !important;
`;
const noticeTitle = document.createElement("div");
noticeTitle.textContent = "CSP Detected";
noticeTitle.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 32px !important;
font-weight: 800 !important;
line-height: 1.1 !important;
margin: 0 0 16px 0 !important;
padding: 0 !important;
text-align: center !important;
letter-spacing: -0.5px !important;
text-shadow: 0 2px 20px rgba(138, 43, 226, 0.6) !important;
`;
const noticeText = document.createElement("div");
noticeText.innerHTML = "This is not supported on your version. Please use the extension version or get the CSP unblock extension.";
noticeText.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 15px !important;
margin: 0 0 30px 0 !important;
padding: 0 !important;
text-align: center !important;
line-height: 1.6 !important;
font-weight: 400 !important;
`;
const buttonContainer = document.createElement("div");
buttonContainer.style.cssText = `
display: flex !important;
flex-direction: column !important;
gap: 12px !important;
`;
const extensionButton = document.createElement("a");
extensionButton.href = "https://github.com/xgui-client/X-GUI-BLOOKET-CLIENT/raw/refs/heads/main/extension/x-gui-extension.zip";
extensionButton.target = "_blank";
extensionButton.textContent = "Get Extension";
extensionButton.style.cssText = `
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
background: linear-gradient(135deg, #5865F2, #4752C4) !important;
color: #FFFFFF !important;
border: none !important;
font-size: 15px !important;
font-weight: 600 !important;
cursor: pointer !important;
padding: 14px 32px !important;
border-radius: 12px !important;
transition: all 0.3s ease !important;
box-shadow: 0 6px 20px rgba(88, 101, 242, 0.4) !important;
margin: 0 !important;
letter-spacing: 0.3px !important;
text-decoration: none !important;
`;
extensionButton.addEventListener('mouseenter', function() {
this.style.transform = 'translateY(-3px) scale(1.02)';
this.style.boxShadow = '0 10px 30px rgba(88, 101, 242, 0.6)';
});
extensionButton.addEventListener('mouseleave', function() {
this.style.transform = 'translateY(0) scale(1)';
this.style.boxShadow = '0 6px 20px rgba(88, 101, 242, 0.4)';
});
buttonContainer.appendChild(extensionButton);
content.appendChild(iconWrapper);
content.appendChild(noticeTitle);
content.appendChild(noticeText);
content.appendChild(buttonContainer);
notice.append(content);
try { cheatsPage.append(notice); } catch (e) { document.body.append(notice); }
return;
}
}
if (unsupportedModes.includes(mode)) {
path.push(cheats[mode].name, cheatsPage);
try {
if (cheatsPage && cheatsPage.style) {
let blurTarget = cheatsPage.querySelector && cheatsPage.querySelector('.xgui-blur-target');
if (!blurTarget) {
blurTarget = document.createElement('div');
blurTarget.className = 'xgui-blur-target';
while (cheatsPage.firstChild) {
blurTarget.appendChild(cheatsPage.firstChild);
}
cheatsPage.appendChild(blurTarget);
}
blurTarget.style.filter = 'blur(8px)';
blurTarget.style.pointerEvents = 'none';
} else if (typeof gui !== 'undefined' && gui.style) {
gui.style.filter = "blur(8px)";
gui.style.pointerEvents = "none";
}
} catch (e) {}
if (cheatsPage.querySelector && cheatsPage.querySelector('.xgui-blur-notice')) return;
const notice = document.createElement("div");
notice.className = 'xgui-blur-notice';
try { if (!cheatsPage.style.position || cheatsPage.style.position === 'static') cheatsPage.style.position = 'relative'; } catch (e) {}
notice.style.cssText = `
position: absolute;
inset: 0;
display: flex !important;
align-items: flex-start !important;
justify-content: center !important;
z-index: 2000;
pointer-events: auto;
text-align: center;
background: transparent;
padding: 20px;
`;
const content = document.createElement('div');
content.className = 'xgui-blur-notice-content';
content.style.cssText = `
box-sizing: border-box !important;
display: block !important;
max-width: 380px !important;
width: 100% !important;
padding: 40px 35px !important;
border-radius: 20px !important;
backdrop-filter: blur(24px) saturate(180%) !important;
-webkit-backdrop-filter: blur(24px) saturate(180%) !important;
background: linear-gradient(145deg, rgba(138, 43, 226, 0.15), rgba(75, 0, 130, 0.1)) !important;
border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
box-shadow:
0 10px 40px rgba(0, 0, 0, 0.5),
0 0 0 1px rgba(255, 255, 255, 0.08) inset,
0 25px 70px rgba(138, 43, 226, 0.2) !important;
text-align: center !important;
margin-top: -40px !important;
`;
const iconWrapper = document.createElement("div");
iconWrapper.innerHTML = `
<svg width="64" height="64" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect x="5" y="11" width="14" height="10" rx="2" stroke="currentColor" stroke-width="2"/>
<path d="M7 11V7C7 4.79086 8.79086 3 11 3H13C15.2091 3 17 4.79086 17 7V11" stroke="currentColor" stroke-width="2" stroke-linecap="round"/>
<circle cx="12" cy="16" r="1.5" fill="currentColor"/>
</svg>
`;
iconWrapper.style.cssText = `
display: block !important;
color: #FFFFFF !important;
margin: 0 auto 20px auto !important;
padding: 0 !important;
line-height: 1 !important;
filter: drop-shadow(0 4px 16px rgba(255, 255, 255, 0.3)) !important;
`;
const noticeTitle = document.createElement("div");
noticeTitle.textContent = "Not Supported";
noticeTitle.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 32px !important;
font-weight: 800 !important;
line-height: 1.1 !important;
margin: 0 0 16px 0 !important;
padding: 0 !important;
text-align: center !important;
letter-spacing: -0.5px !important;
text-shadow: 0 2px 20px rgba(138, 43, 226, 0.6) !important;
`;
const noticeText = document.createElement("div");
noticeText.innerHTML = "Cheats for this gamemode are still in development. Join the discord to find out when its done.";
noticeText.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 15px !important;
margin: 0 0 30px 0 !important;
padding: 0 !important;
text-align: center !important;
line-height: 1.6 !important;
font-weight: 400 !important;
`;
const discordButton = document.createElement("a");
discordButton.href = "https://discord.gg/A7CRUz8vFR";
discordButton.target = "_blank";
discordButton.innerHTML = `
<svg width="24" height="24" viewBox="0 0 24 24" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
<path d="M20.317 4.37a19.791 19.791 0 0 0-4.885-1.515a.074.074 0 0 0-.079.037c-.21.375-.444.864-.608 1.25a18.27 18.27 0 0 0-5.487 0a12.64 12.64 0 0 0-.617-1.25a.077.077 0 0 0-.079-.037A19.736 19.736 0 0 0 3.677 4.37a.07.07 0 0 0-.032.027C.533 9.046-.32 13.58.099 18.057a.082.082 0 0 0 .031.057a19.9 19.9 0 0 0 5.993 3.03a.078.078 0 0 0 .084-.028a14.09 14.09 0 0 0 1.226-1.994a.076.076 0 0 0-.041-.106a13.107 13.107 0 0 1-1.872-.892a.077.077 0 0 1-.008-.128a10.2 10.2 0 0 0 .372-.292a.074.074 0 0 1 .077-.01c3.928 1.793 8.18 1.793 12.062 0a.074.074 0 0 1 .078.01c.12.098.246.198.373.292a.077.077 0 0 1-.006.127a12.299 12.299 0 0 1-1.873.892a.077.077 0 0 0-.041.107c.36.698.772 1.362 1.225 1.993a.076.076 0 0 0 .084.028a19.839 19.839 0 0 0 6.002-3.03a.077.077 0 0 0 .032-.054c.5-5.177-.838-9.674-3.549-13.66a.061.061 0 0 0-.031-.03zM8.02 15.33c-1.183 0-2.157-1.085-2.157-2.419c0-1.333.956-2.419 2.157-2.419c1.21 0 2.176 1.096 2.157 2.42c0 1.333-.956 2.418-2.157 2.418zm7.975 0c-1.183 0-2.157-1.085-2.157-2.419c0-1.333.955-2.419 2.157-2.419c1.21 0 2.176 1.096 2.157 2.42c0 1.333-.946 2.418-2.157 2.418z"/>
</svg>
<span style="margin-left: 8px;">Join Discord</span>
`;
discordButton.style.cssText = `
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
background: linear-gradient(135deg, #5865F2, #4752C4) !important;
color: #FFFFFF !important;
border: none !important;
font-size: 15px !important;
font-weight: 600 !important;
cursor: pointer !important;
padding: 14px 32px !important;
border-radius: 12px !important;
transition: all 0.3s ease !important;
box-shadow: 0 6px 20px rgba(88, 101, 242, 0.4) !important;
margin: 0 !important;
letter-spacing: 0.3px !important;
text-decoration: none !important;
`;
discordButton.addEventListener('mouseenter', function() {
this.style.transform = 'translateY(-3px) scale(1.02)';
this.style.boxShadow = '0 10px 30px rgba(88, 101, 242, 0.6)';
});
discordButton.addEventListener('mouseleave', function() {
this.style.transform = 'translateY(0) scale(1)';
this.style.boxShadow = '0 6px 20px rgba(88, 101, 242, 0.4)';
});
content.appendChild(iconWrapper);
content.appendChild(noticeTitle);
content.appendChild(noticeText);
content.appendChild(discordButton);
notice.append(content);
try { cheatsPage.append(notice); } catch (e) { document.body.append(notice); }
} else {
path.push(cheats[mode].name, cheatsPage);
}
};
gamemodesList.append(gamemode);
}
gamemodesPage.append(gamemodesList);
const creditsPage = document.createElement("div");
creditsPage.className = classes.creditsPage;
// Create sleek Changelog Page
const changelogPage = document.createElement("div");
changelogPage.className = classes.favoritesPage || "favoritesPage";
Object.assign(changelogPage.style, {
display: "flex",
flexDirection: "column",
gap: "16px",
padding: "25px 20px 50px 20px", // <-- add extra bottom padding
overflowY: "auto"
});
// Add custom scrollbar style
const styleEl = document.createElement("style");
styleEl.textContent = `
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar {
width: 8px;
}
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar-thumb {
background: var(--highlight2);
border-radius: 4px;
}
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar-track {
background: transparent;
}`;
document.head.appendChild(styleEl);
// Title
const title = document.createElement("div");
title.className = "bigTextContainer";
title.innerHTML = `<div class="bigText">📜 Changelog</div>`;
Object.assign(title.style, {
fontSize: "2.2em",
fontWeight: "900",
textAlign: "center",
marginBottom: "15px",
textShadow: `0 0 12px var(--highlight), 0 0 24px var(--highlight2)`
});
changelogPage.appendChild(title);
// Versions array (30 versions, highest to lowest)
const versions = [
["Version 6.70x", "ADDED SMOOTH GUI ANIMATIONS, FIXED CUSTOM MODULE BUGS, ALLOWED TEXT VALUES FOR STATS, FIXED CRYPTO STEALING, ADDED SPAM CRYPTO HACK, UPDATED ICONS, FIXED STORAGE SYNC, AND UPDATED CREDITS.", "null"],
["Version 6.69x", "ADDED CSP DETECTOR FOR CUSTOM MODULES, FIXED CUSTOM MODULES BUG, FIXED STORAGE ISSUE ADDED IMAGE FIX AND ADDED FREE PLUS!.", "null"],
["Version 6.68x", "ADDED SMOOTH ANIMATIONS FOR X-GUI, ADDED CUSTOM MODULES, AND NOW YOU CAN DRAG THE TOP AREA.", "null"],
["Version 6.67x", "ADDED SWAL ALERTS! TOGGLE, ADDED UNSUPPORTED GAMEMODE WARNINGS, AND MOVED SETTINGS MENU.", "null"],
["Version 6.66x", "ADDED SWAL ALERTS!", "null"],
["Version 6.65x", "ADDED CLIENT SIDED BLOOK EDITOR", "null"],
["Version 6.64x", "FIXED MOST GAMEMODES", "null"],
["Version 6.63x", "ADDED BLOOK EDITOR AND UPDATED MOBILE MODE", "null"],
["Version 6.62x", "ADDED ACCOUNT GENERATOR", "null"],
["Version 6.61x", "ADDED BLOOKET STREAM FINDER AND ALT MANAGER", "null"],
["Version 6.60x", "fixed ping display! ADDED CONSOLE MESSAGE AND ADDED PIN GUESSER!!", "null"],
["Version 6.50x", "FIXED KEYBINDS!! ADDED CHEATS AND ADDED 8 NEW THEMES, HAPPY HOLIDAYS GUYSS <3", "null"],
["Version 6.40x", "UPDATED REFRESH SVG AND ADDED CHEAT", "null"],
["Version 6.30x", "ADDED CHEATS AND UPDATED GUI", "null"],
["Version 6.20x", "ADDED MORE CHEATS+++", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 6.10x", "ADDED WHAT YOU ARE READING RN", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 6.00x", "ADDED MOBILE MODE + A BUNCH MORE CRAP", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.90x", "ROUNDED CORNERS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.80x", "UPDATED XTRAS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.70x", "ADDED EXTRAS TAB", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.60x", "STOP COMPLAINING (FIXED BUGS)", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.50x", "BUGS AND MORE BUGS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.40x", "UPDATED VERSIONNAME VARIABLE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.30x", "UPDATED BLOOKET BOT", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.20x", "ADDED REMOVE ALL TAKEN BLOOKS TO THE GLOBAL STATENODE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.10x", "ADDED BLOOKET BOT", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 5.00x", "ADDED FREEZE LEADERBOARD", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.90x", "ADDED CHANGE GAME CODE TO FLAPPY BLOOK", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.80x", "ADDED CLIENT SIDE FRENZY", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.70x", "REMOVED THE . FROM THE TITLE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.60x", "ADDED FLOOD ALERT BOX", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.50x", "FIXED SEVERAL BUGS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.40x", "FIXED THE DOUBLE ERROR (SORRY GUYS!)", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.30x", "FIXED SPELLING ERROR", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.20x", "ADDED USERSCRIPT IMAGE!!!", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.10x", "BUGS FIXED (AGAIN)", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 4.00x", "BUGS FIXED", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.90x", "FIXED A SPELLING ERROR", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.80x", "BUGS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.70x", "ATTEMPTED AN UPDATE BUT FAILED :(", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.60x", "DID SOME UI STUFF", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.50x", "FIXED A FEW BUS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.40x", "NEW CHEATS ADDED", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.30x", "FIXED SUBDOMAIN ISSUE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.20x", "ADDED SIMULATE UNLOCK, ALWAYS HACK, HOST ANY GAMEMODE, BYPASS FILTER, CRASH HOST, STEAL ALL PLAYERS GOLD AND BYPASS JOIN LIMIT", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.10x", "ADDED 7 NEW CHEATS", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 3.00x", "BUG FIXED", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.90x", "ADDED BYPASS NAME FILTER", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.80x", "ADDED 3 NEW CHEATS TO CRYPTO AND GOLD QUEST", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.70x", "ADDED WELCOME MESSAGE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.60x", "ADDED GLOW EFFECT TO TITLE", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.50x", "REVAMPED COLORS AND UI", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.40x", "STARTED WITH NEW COLOR SCHEME", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.30x", "FIXED USE ANY BLOOK", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.20x", "BUG FIXED", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"],
["Version 2.10x", "STARTED NEW MENU", "https://greasyfork.org/en/scripts/553301-x-gui-client-for-blooket/versions"]
];
// Add each version as a sleek card
versions.forEach(([ver, desc, link]) => {
const card = document.createElement("div");
Object.assign(card.style, {
display: "flex",
flexDirection: "column",
gap: "6px",
padding: "16px 20px",
borderRadius: "14px",
background: "var(--background2)",
boxShadow: "0 5px 20px rgba(0,0,0,0.28)",
transition: "transform 0.2s ease, box-shadow 0.2s ease",
cursor: "default"
});
card.onmouseover = () => {
card.style.transform = "translateY(-4px)";
card.style.boxShadow = "0 10px 30px rgba(0,0,0,0.35)";
};
card.onmouseleave = () => {
card.style.transform = "translateY(0)";
card.style.boxShadow = "0 5px 20px rgba(0,0,0,0.28)";
};
const verTitle = document.createElement("span");
verTitle.style.fontWeight = "700";
verTitle.style.fontSize = "1.2em";
verTitle.style.color = "var(--highlight)";
verTitle.innerText = ver;
const verDesc = document.createElement("span");
verDesc.style.fontSize = "0.95em";
verDesc.style.color = "var(--textColor2)";
verDesc.innerText = desc;
card.append(verTitle, verDesc);
changelogPage.appendChild(card);
});
// Append to GUI content
guiContent.appendChild(changelogPage);
// ================= ALT MANAGER PAGE =================
const altPage = document.createElement("div");
altPage.className = classes.favoritesPage || "favoritesPage";
Object.assign(altPage.style, {
display: "flex",
flexDirection: "column",
gap: "16px",
padding: "25px 20px 50px 20px",
overflowY: "auto"
});
// ===== Styles =====
const altStyle = document.createElement("style");
altStyle.textContent = `
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar {
width: 8px;
}
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar-thumb {
background: var(--highlight2);
border-radius: 4px;
}
.${classes.favoritesPage || "favoritesPage"}::-webkit-scrollbar-track {
background: transparent;
}
.altInput {
background: rgba(255,255,255,0.06);
border: 1px solid rgba(255,255,255,0.15);
border-radius: 12px;
padding: 10px 12px;
color: var(--textColor);
font-size: .95em;
outline: none;
transition: border .2s ease, box-shadow .2s ease, background .2s ease;
}
.altInput::placeholder { color: rgba(255,255,255,.45); }
.altInput:focus {
border-color: var(--highlight);
background: rgba(255,255,255,0.08);
box-shadow: 0 0 0 2px rgb(from var(--highlight) r g b / 35%);
}
.altBtn {
padding: 10px;
border-radius: 14px;
font-weight: 800;
cursor: pointer;
border: none;
color: #000;
background: linear-gradient(135deg, var(--highlight), var(--highlight2));
box-shadow: 0 6px 20px rgb(from var(--highlight) r g b / 45%);
transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.altBtn:hover {
transform: translateY(-2px);
filter: brightness(1.1);
box-shadow: 0 10px 30px rgb(from var(--highlight) r g b / 55%);
}
.altBtn:active {
transform: translateY(0);
box-shadow: 0 4px 14px rgb(from var(--highlight) r g b / 35%);
}
.altSmallBtn { padding: 6px 10px; border-radius: 10px; font-weight: 700; font-size: .8em; }
`;
document.head.appendChild(altStyle);
// ===== Title =====
const altTitle = document.createElement("div");
altTitle.className = "bigTextContainer";
altTitle.innerHTML = `<div class="bigText">👥 Alt Manager</div>`;
Object.assign(altTitle.style, {
fontSize: "2.2em",
fontWeight: "900",
textAlign: "center",
marginBottom: "10px",
textShadow: `0 0 12px var(--highlight), 0 0 24px var(--highlight2)`
});
altPage.appendChild(altTitle);
// ===== Add Alt Card =====
const addAltCard = document.createElement("div");
Object.assign(addAltCard.style, {
display: "flex",
flexDirection: "column",
gap: "10px",
padding: "16px 20px",
borderRadius: "14px",
background: "var(--background2)",
boxShadow: "0 5px 20px rgba(0,0,0,0.28)"
});
addAltCard.innerHTML = `
<span style="font-weight:800;color:var(--highlight)">Add Alt</span>
<input id="altUser" class="altInput" placeholder="Username">
<div style="display:flex;gap:8px;align-items:center">
<input id="altPass" class="altInput" type="password" placeholder="Password" style="flex:1">
<button id="toggleAddPass" class="altBtn altSmallBtn">👁</button>
</div>
<button id="saveAltBtn" class="altBtn">➕ Save Alt</button>
`;
altPage.appendChild(addAltCard);
// ===== Alt List =====
const altList = document.createElement("div");
Object.assign(altList.style, {
display: "flex",
flexDirection: "column",
gap: "12px"
});
altPage.appendChild(altList);
// ===== Cookie Storage Helpers =====
function setCookie(name, value, days = 365) {
const expires = new Date(Date.now() + days * 864e5).toUTCString();
const domain = location.hostname.split('.').slice(-2).join('.'); // save on root domain
document.cookie = `${name}=${encodeURIComponent(value)}; expires=${expires}; path=/; domain=.blooket.com; SameSite=Lax`;
}
function getCookie(name) {
const match = document.cookie.match(new RegExp('(^| )' + name + '=([^;]+)'));
return match ? decodeURIComponent(match[2]) : null;
}
function areSweetAlertsEnabled() {
const cookieValue = getCookie("sweetAlertsEnabled");
return cookieValue === null ? true : cookieValue === "true";
}
// ===== Storage =====
const ALT_KEY = "xgui_alts";
const getAlts = () => {
const cookie = getCookie(ALT_KEY);
return cookie ? JSON.parse(cookie) : [];
};
const setAlts = (alts) => setCookie(ALT_KEY, JSON.stringify(alts));
// ===== Render =====
function renderAlts() {
altList.innerHTML = "";
const alts = getAlts();
if (!alts.length) {
const empty = document.createElement("div");
empty.style.opacity = ".6";
empty.innerText = "No alts saved";
altList.appendChild(empty);
return;
}
alts.forEach((alt, index) => {
let visible = false;
const card = document.createElement("div");
Object.assign(card.style, {
display: "flex",
flexDirection: "column",
gap: "8px",
padding: "16px 20px",
borderRadius: "14px",
background: "var(--background2)",
boxShadow: "0 5px 20px rgba(0,0,0,0.28)",
transition: "transform .2s ease, box-shadow .2s ease"
});
card.onmouseover = () => {
card.style.transform = "translateY(-4px)";
card.style.boxShadow = "0 10px 30px rgba(0,0,0,0.35)";
};
card.onmouseleave = () => {
card.style.transform = "translateY(0)";
card.style.boxShadow = "0 5px 20px rgba(0,0,0,0.28)";
};
const passSpan = document.createElement("span");
passSpan.style.opacity = ".6";
passSpan.innerText = "••••••••";
const viewBtn = document.createElement("button");
viewBtn.className = "altBtn altSmallBtn";
viewBtn.innerText = "👁 View";
viewBtn.onclick = () => {
visible = !visible;
passSpan.innerText = visible ? alt.pass : "••••••••";
viewBtn.innerText = visible ? "🙈 Hide" : "👁 View";
};
const removeBtn = document.createElement("button");
removeBtn.className = "altBtn altSmallBtn";
removeBtn.innerText = "Remove";
removeBtn.onclick = () => {
const all = getAlts();
all.splice(index, 1);
setAlts(all);
renderAlts();
};
card.append(
Object.assign(document.createElement("span"), {
innerText: alt.user,
style: "font-weight:800;color:var(--highlight)"
}),
passSpan,
viewBtn,
removeBtn
);
altList.appendChild(card);
});
}
// ===== Add Alt Logic =====
const addPassInput = addAltCard.querySelector("#altPass");
addAltCard.querySelector("#toggleAddPass").onclick = () => {
addPassInput.type = addPassInput.type === "password" ? "text" : "password";
};
addAltCard.querySelector("#saveAltBtn").onclick = () => {
const user = addAltCard.querySelector("#altUser").value.trim();
const pass = addPassInput.value.trim();
if (!user || !pass) return;
const alts = getAlts();
alts.push({
user,
pass
});
setAlts(alts);
addAltCard.querySelector("#altUser").value = "";
addPassInput.value = "";
addPassInput.type = "password";
renderAlts();
};
// Refresh on open
altPage.onPath = renderAlts;
const blookPage = document.createElement("div");
blookPage.className = classes.favoritesPage || "favoritesPage";
Object.assign(blookPage.style, {
display: "flex",
flexDirection: "column",
gap: "18px",
padding: "25px 20px 50px 20px",
overflowY: "auto"
});
const Blookstyle = document.createElement("style");
Blookstyle.textContent = `
.blookPage::-webkit-scrollbar { width: 6px; }
.blookPage::-webkit-scrollbar-thumb { background: #5b4bdb; border-radius: 4px; }
.editorContainer {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 16px;
padding: 18px;
border-radius: 18px;
background: rgba(18,22,46,0.85);
}
.blookInput {
width: 70px;
padding: 8px;
border-radius: 12px;
border: 1px solid rgba(120,100,255,0.25);
background: rgba(20,25,55,0.65);
color: #fff;
text-align: center;
}
.previewBox {
width: 220px;
height: 220px;
margin: 0 auto;
background: rgba(10,12,30,0.7);
border-radius: 20px;
border: 1px solid rgba(120,100,255,0.35);
display: flex;
align-items: center;
justify-content: center;
}
.previewStack {
position: relative;
width: 180px;
height: 180px;
}
.previewStack img {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
pointer-events: none;
}
.finalConfigInput {
width: 92%;
margin: 0 auto;
padding: 12px;
border-radius: 14px;
background: rgba(20,25,55,0.75);
border: 1px solid rgba(120,100,255,0.25);
color: #fff;
font-weight: 700;
text-align: center;
}
.blookBtn {
margin: 14px auto 0;
padding: 12px 26px;
border-radius: 14px;
border: none;
cursor: pointer;
font-weight: 900;
color: #fff;
background: linear-gradient(135deg, #8f6bff, #5b4bdb);
}
`;
document.head.appendChild(Blookstyle);
blookPage.innerHTML += `
<div style="text-align:center">
<div style="font-size:2em;font-weight:900;color:#fff">🖌️ Blook Editor</div>
</div>
`;
const editorContainer = document.createElement("div");
editorContainer.className = "editorContainer";
blookPage.appendChild(editorContainer);
function createInput(label) {
const wrap = document.createElement("div");
wrap.style.display = "flex";
wrap.style.flexDirection = "column";
wrap.style.alignItems = "center";
wrap.style.gap = "6px";
const l = document.createElement("label");
l.textContent = label;
l.style.color = "#fff";
l.style.fontWeight = "600";
const i = document.createElement("input");
i.type = "number";
i.min = 0;
i.value = 0;
i.className = "blookInput";
wrap.append(l, i);
editorContainer.appendChild(wrap);
return i;
}
const parts = {
base: createInput("Base"),
clothing: createInput("Clothing"),
eyes: createInput("Eyes"),
glasses: createInput("Glasses"),
hair: createInput("Hair"),
hairColor: createInput("Hair Color"),
hat: createInput("Hat"),
item: createInput("Item"),
mouth: createInput("Mouth"),
nose: createInput("Nose"),
cheeks: createInput("Cheeks"),
eyebrows: createInput("Eyebrows"),
eyebrowsColor: createInput("Eyebrows Color")
};
const previewBox = document.createElement("div");
previewBox.className = "previewBox";
const previewStack = document.createElement("div");
previewStack.className = "previewStack";
previewBox.appendChild(previewStack);
blookPage.appendChild(previewBox);
const GITHUB_BASE =
"https://raw.githubusercontent.com/0alter0/blook-parts/241bda5908c9355caef55ac994b1c2ec21124eb7";
const PART_FOLDER_MAP = {
base: "base",
clothing: "clothing",
eyes: "eyes",
glasses: "glasses",
hair: "hair",
hat: "hats",
item: "items",
mouth: "mouths",
nose: "nose",
cheeks: "cheeks",
eyebrows: "eyebrows"
};
const RENDER_ORDER = [
"base",
"clothing",
"cheeks",
"nose",
"eyes",
"eyebrows",
"mouth",
"glasses",
"hair",
"hat",
"item"
];
function renderStack() {
previewStack.innerHTML = "";
RENDER_ORDER.forEach(part => {
const input = parts[part];
if (!input) return;
const id = Number(input.value);
const folder = PART_FOLDER_MAP[part];
if (!folder) return;
if (part === "base") {
if (id < 0) return;
} else {
if (id <= 0) return;
}
const img = document.createElement("img");
img.src = `${GITHUB_BASE}/${folder}/item${id}.svg`;
img.onerror = () => img.remove();
previewStack.appendChild(img);
});
}
const finalConfig = document.createElement("input");
finalConfig.className = "finalConfigInput";
blookPage.appendChild(finalConfig);
function updateConfig() {
const v = Object.values(parts).map(i => i.value || 0);
finalConfig.value =
`${v[0]}#${v[1]}#${v[2]}#${v[3]}#${v[4]}` +
`$${v[5]}#${v[6]}#${v[7]}#${v[8]}#${v[9]}` +
`#${v[10]}#${v[11]}$${v[12]}`;
}
Object.values(parts).forEach(i => {
i.addEventListener("input", () => {
updateConfig();
renderStack();
});
});
updateConfig();
renderStack();
const setBtn = document.createElement("button");
setBtn.className = "blookBtn";
setBtn.textContent = "Set Blook";
blookPage.appendChild(setBtn);
setBtn.onclick = () => {
const blook = finalConfig.value;
let t = Object.values(function e(t = document.querySelector("body>div")) {
return Object.values(t)[1]?.children?.[0]?._owner?.stateNode ?
t :
e(t.querySelector(":scope>div"));
}())[1].children[0]._owner.stateNode;
if (!t.state.unlocks) t.props.client.blook = blook;
t.props.liveGameController.setVal({
path: `c/${t.props.client.name}/b`,
val: blook
});
};
//Written by Lil Skittle
// ================= CLIENT PAGE =================
const clientPage = document.createElement("div");
clientPage.className = classes.favoritesPage || "favoritesPage";
Object.assign(clientPage.style, {
display: "flex",
flexDirection: "column",
justifyContent: "center",
alignItems: "center",
gap: "30px",
padding: "40px 20px",
overflowY: "auto"
});
// ===== STYLE =====
const clientStyle = document.createElement("style");
clientStyle.textContent = `
.clientCard {
background: var(--background2);
border-radius: 22px;
padding: 36px 34px;
box-shadow: 0 12px 40px rgba(0,0,0,.35);
display: flex;
flex-direction: column;
align-items: center;
gap: 24px;
}
.clientLaunchBtn {
padding: 18px 46px;
border-radius: 18px;
font-size: 1.15em;
font-weight: 900;
cursor: pointer;
border: none;
color: #fff;
background: linear-gradient(135deg,#8f6bff,#5b4bdb);
box-shadow: 0 10px 30px rgba(120,100,255,.45);
transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.clientLaunchBtn:hover {
transform: translateY(-4px);
filter: brightness(1.12);
box-shadow: 0 18px 45px rgba(120,100,255,.6);
}
.clientLaunchBtn:active {
transform: translateY(-1px);
box-shadow: 0 8px 20px rgba(120,100,255,.4);
}
`;
document.head.appendChild(clientStyle);
// ===== TITLE =====
const clienttitle = document.createElement("div");
clienttitle.innerHTML = `
<div style="
font-size:2.4em;
font-weight:900;
text-align:center;
color:#fff;
text-shadow:0 0 14px var(--highlight),0 0 28px var(--highlight2);
">🧩 Client Sided Blook Menu</div>
<div style="opacity:.65;font-weight:600;text-align:center;margin-top:6px">
Customize your Blook to your style!
</div>
`;
// ===== CARD =====
const card = document.createElement("div");
card.className = "clientCard";
// ===== LAUNCH BUTTON =====
const launchBtn = document.createElement("button");
launchBtn.className = "clientLaunchBtn";
launchBtn.textContent = "Open Blook Customizer";
launchBtn.onclick = () => {
if (document.getElementById("xgui-blook-customizer")) return;
// ===== DRAGGABLE CUSTOMIZER GUI =====
const gui = document.createElement("div");
gui.id = "xgui-blook-customizer";
Object.assign(gui.style, {
position: "fixed",
top: "120px",
left: "120px",
zIndex: "99999",
width: "250px",
padding: "12px",
background: "linear-gradient(180deg,#140f1f,#0b0812)",
color: "#eee",
borderRadius: "14px",
border: "1px solid #2a1f3d",
fontFamily: "Inter, system-ui, sans-serif",
display: "flex",
flexDirection: "column",
gap: "10px",
boxShadow: "0 12px 40px rgba(120,80,255,.25)",
userSelect: "none"
});
// ===== HEADER =====
const header = document.createElement("div");
Object.assign(header.style, {
display: "flex",
justifyContent: "space-between",
alignItems: "center",
height: "28px",
padding: "0 4px",
fontWeight: "700",
fontSize: "13px",
color: "#cdbbff",
cursor: "grab"
});
header.textContent = "Blook Customizer";
const close = document.createElement("button");
close.textContent = "✕";
Object.assign(close.style, {
background: "none",
border: "none",
color: "#7f6ab8",
fontSize: "16px",
cursor: "pointer"
});
close.onclick = () => gui.remove();
header.appendChild(close);
gui.appendChild(header);
// ===== DRAG =====
let drag = false,
dx = 0,
dy = 0;
header.onmousedown = e => {
drag = true;
dx = e.clientX - gui.offsetLeft;
dy = e.clientY - gui.offsetTop;
header.style.cursor = "grabbing";
};
document.onmousemove = e => {
if (!drag) return;
gui.style.left = e.clientX - dx + "px";
gui.style.top = e.clientY - dy + "px";
};
document.onmouseup = () => {
drag = false;
header.style.cursor = "grab";
};
// ===== STACK =====
const stack = () => {
const d = document.createElement("div");
Object.assign(d.style, {
display: "flex",
flexDirection: "column",
gap: "6px"
});
return d;
};
// ===== INPUT =====
const input = ph => {
const i = document.createElement("input");
i.placeholder = ph;
Object.assign(i.style, {
width: "100%",
height: "36px",
padding: "0 12px",
background: "#0f0b18",
color: "#eee",
border: "1px solid #2e2450",
borderRadius: "10px",
fontSize: "12.5px",
boxSizing: "border-box",
outline: "none"
});
i.onfocus = () => i.style.borderColor = "#8b5cf6";
i.onblur = () => i.style.borderColor = "#2e2450";
return i;
};
// ===== BUTTON =====
const btn = (t, bg) => {
const b = document.createElement("button");
b.textContent = t;
Object.assign(b.style, {
height: "38px",
borderRadius: "10px",
border: "none",
cursor: "pointer",
fontWeight: "700",
color: "#fff",
background: bg
});
b.onmouseenter = () => b.style.filter = "brightness(1.12)";
b.onmouseleave = () => b.style.filter = "none";
return b;
};
const custom = stack();
const imgIn = input("Blook Image URL");
const bgIn = input("Background URL");
const nameIn = input("Blook Name");
const rareIn = input("Rarity Name");
const colIn = input("Rarity Color");
custom.append(imgIn, bgIn, nameIn, rareIn, colIn);
const apply = btn("Apply Custom", "linear-gradient(135deg,#7c3aed,#5b21b6)");
const seedStack = stack();
const seedIn = input("Seed");
const load = btn("Load Seed", "linear-gradient(135deg,#22c55e,#16a34a)");
const get = btn("Get Seed", "#1a1626");
seedStack.append(seedIn, load, get);
gui.append(custom, apply, seedStack);
document.body.appendChild(gui);
// ===== LOGIC (UNCHANGED) =====
const updateBlook = (img, bg, name, rare, col) => {
const b = document.querySelector('img[class*="blook"]');
const g = document.querySelector('img[class*="_rightBackground"]');
const n = document.querySelector('div[style*="white-space: nowrap"]');
const r = document.querySelector('div[class*="Rarity"]');
if (b && img) b.src = img;
if (g && bg) g.src = bg;
if (r) {
if (rare) r.textContent = rare;
if (col) r.style.color = col;
}
if (n && name) {
n.textContent = name;
let s = 39;
n.style.fontSize = s + "px";
while (n.scrollWidth > n.parentElement.clientWidth && s > 1) {
n.style.fontSize = --s + "px";
}
}
};
apply.onclick = () =>
updateBlook(imgIn.value, bgIn.value, nameIn.value, rareIn.value, colIn.value);
get.onclick = () => {
const b = document.querySelector('img[class*="blook"]');
const g = document.querySelector('img[class*="_rightBackground"]');
const n = document.querySelector('div[style*="white-space: nowrap"]');
const r = document.querySelector('div[class*="Rarity"]');
seedIn.value = btoa(unescape(encodeURIComponent(JSON.stringify({
img: b?.src,
bg: g?.src,
name: n?.textContent,
rare: r?.textContent,
col: r?.style.color
}))));
};
load.onclick = () => {
try {
const d = JSON.parse(decodeURIComponent(escape(atob(seedIn.value))));
updateBlook(d.img, d.bg, d.name, d.rare, d.col);
} catch {
alert("Invalid Seed");
}
};
};
// ===== BUILD =====
card.append(launchBtn);
clientPage.append(clienttitle, card);
// ================= CUSTOM MODULES PAGE =================
const modulePage = document.createElement("div");
modulePage.className = classes.favoritesPage || "favoritesPage";
// JavaScript minification function
function minifyJS(code) {
try {
return code
// Remove single-line comments
.replace(/\/\/.*$/gm, '')
// Remove multi-line comments
.replace(/\/\*[\s\S]*?\*\//g, '')
// Remove extra whitespace
.replace(/\s+/g, ' ')
// Remove whitespace around operators and punctuation
.replace(/\s*([{}();,:<>!=+\-*/%&|?])\s*/g, '$1')
// Remove whitespace after keywords
.replace(/\b(return|var|let|const|if|else|for|while|function|class)\s+/g, '$1 ')
.trim();
} catch (e) {
console.error('Minification error:', e);
return code; // Return original code if minification fails
}
}
Object.assign(modulePage.style, {
display: "flex",
flexDirection: "column",
alignItems: "center",
gap: "28px",
padding: "40px 20px",
overflowY: "auto",
minHeight: "100vh"
});
const moduleStyle = document.createElement("style");
moduleStyle.textContent = `
.moduleCard {
background: linear-gradient(135deg, rgba(30, 25, 50, 0.8), rgba(20, 18, 35, 0.9));
border-radius: 18px;
padding: 36px;
box-shadow: 0 8px 24px rgba(0,0,0,.25);
border: 1px solid rgba(143,107,255,.15);
display: flex;
flex-direction: column;
gap: 20px;
width: 100%;
max-width: 650px;
}
.moduleBtn {
padding: 15px 36px;
border-radius: 10px;
font-size: 1.05em;
font-weight: 700;
cursor: pointer;
border: none;
color: #fff;
background: linear-gradient(135deg, #6366f1, #4f46e5);
box-shadow: 0 4px 12px rgba(99,102,241,.3);
transition: all .2s ease;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
gap: 10px;
}
.moduleBtn:hover {
background: linear-gradient(135deg, #4f46e5, #4338ca);
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(99,102,241,.4);
}
.moduleBtn:active {
transform: translateY(0);
}
.moduleSecondaryBtn {
background: linear-gradient(135deg, #374151, #1f2937);
border: 1px solid rgba(255,255,255,.1);
box-shadow: 0 4px 12px rgba(0,0,0,.2);
}
.moduleSecondaryBtn:hover {
background: linear-gradient(135deg, #4b5563, #374151);
border-color: rgba(255,255,255,.15);
}
.moduleDangerBtn {
background: linear-gradient(135deg, #ef4444, #dc2626);
box-shadow: 0 4px 12px rgba(239,68,68,.3);
}
.moduleDangerBtn:hover {
background: linear-gradient(135deg, #dc2626, #b91c1c);
box-shadow: 0 6px 16px rgba(239,68,68,.4);
}
.buttonGrid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 14px;
width: 100%;
}
.buttonGrid.centered {
justify-content: center;
grid-template-columns: repeat(auto-fit, minmax(200px, 250px));
}
.clearAllContainer {
display: flex;
justify-content: center;
width: 100%;
margin-top: 4px;
}
.clearAllBtn {
max-width: 300px;
}
.moduleManageBtn {
background: linear-gradient(135deg, #8b5cf6, #7c3aed);
box-shadow: 0 4px 12px rgba(139,92,246,.3);
}
.moduleManageBtn:hover {
background: linear-gradient(135deg, #7c3aed, #6d28d9);
box-shadow: 0 6px 16px rgba(139,92,246,.4);
}
.swal2-popup {
background: #1a1625 !important;
border: 1px solid rgba(143,107,255,.2) !important;
}
.swal2-title {
color: #fff !important;
}
.swal2-html-container {
color: rgba(255,255,255,.85) !important;
}
.swal2-container .moduleItemCard {
background: linear-gradient(135deg, rgba(40, 35, 60, 0.6), rgba(30, 25, 50, 0.8));
border: 1px solid rgba(143,107,255,.2);
border-radius: 14px;
padding: 22px;
margin-bottom: 14px;
transition: all .2s ease;
text-align: left;
display: flex;
justify-content: space-between;
align-items: center;
gap: 16px;
}
.swal2-container .moduleItemCard:hover {
border-color: rgba(143,107,255,.4);
background: linear-gradient(135deg, rgba(50, 45, 70, 0.7), rgba(40, 35, 60, 0.9));
transform: translateY(-3px);
box-shadow: 0 6px 18px rgba(0,0,0,.3);
}
.swal2-container .moduleItemInfo {
flex: 1;
}
.swal2-container .moduleItemActions {
display: flex;
gap: 10px;
flex-shrink: 0;
}
.swal2-container .moduleActionBtn {
width: 38px;
height: 38px;
border-radius: 10px;
border: none;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: all .2s ease;
}
.swal2-container .moduleEditBtn {
background: linear-gradient(135deg, #6366f1, #4f46e5);
box-shadow: 0 2px 8px rgba(99,102,241,.3);
}
.swal2-container .moduleEditBtn:hover {
background: linear-gradient(135deg, #4f46e5, #4338ca);
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(99,102,241,.4);
}
.swal2-container .moduleDeleteBtn {
background: linear-gradient(135deg, #ef4444, #dc2626);
box-shadow: 0 2px 8px rgba(239,68,68,.3);
}
.swal2-container .moduleDeleteBtn:hover {
background: linear-gradient(135deg, #dc2626, #b91c1c);
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(239,68,68,.4);
}
.swal2-container .moduleItemTitle {
font-size: 1.15em;
font-weight: 700;
color: #fff;
margin-bottom: 8px;
}
.swal2-container .moduleItemDesc {
color: rgba(255,255,255,.65);
font-size: 0.92em;
line-height: 1.5;
margin-bottom: 10px;
}
.swal2-container .moduleItemType {
display: inline-block;
padding: 5px 12px;
background: rgba(99,102,241,.2);
border: 1px solid rgba(99,102,241,.35);
border-radius: 14px;
font-size: 0.78em;
font-weight: 700;
color: #a5b4fc;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.swal2-confirm, .swal2-deny, .swal2-cancel {
font-weight: 600 !important;
padding: 10px 24px !important;
border-radius: 8px !important;
}
.swal2-select {
color: #000 !important;
background: #fff !important;
}
.helpBtn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
border-radius: 50%;
background: rgba(99,102,241,.15);
border: 1.5px solid rgba(99,102,241,.3);
color: #a5b4fc;
font-size: 1em;
font-weight: 700;
cursor: pointer;
transition: all .2s ease;
margin-left: 10px;
vertical-align: middle;
}
.helpBtn:hover {
background: rgba(99,102,241,.25);
border-color: rgba(99,102,241,.5);
transform: scale(1.1);
}
.docContainer {
max-height: 500px;
overflow-y: auto;
text-align: left;
padding: 20px;
background: rgba(20, 18, 35, 0.4);
border-radius: 12px;
margin-bottom: 20px;
}
.docSection {
margin-bottom: 24px;
}
.docTitle {
font-size: 1.3em;
font-weight: 700;
color: #fff;
margin-bottom: 12px;
display: flex;
align-items: center;
gap: 8px;
}
.docSubtitle {
font-size: 1.1em;
font-weight: 600;
color: #a5b4fc;
margin-bottom: 8px;
margin-top: 16px;
}
.docText {
color: rgba(255,255,255,.75);
line-height: 1.6;
margin-bottom: 12px;
}
.docCode {
background: rgba(0,0,0,.3);
border: 1px solid rgba(99,102,241,.2);
border-radius: 8px;
padding: 12px;
font-family: monospace;
font-size: 0.9em;
color: #e0e7ff;
overflow-x: auto;
margin: 8px 0;
}
.docHighlight {
color: #a5b4fc;
font-weight: 600;
}
.docList {
margin-left: 20px;
color: rgba(255,255,255,.75);
line-height: 1.8;
}
`;
document.head.appendChild(moduleStyle);
const modTitle = document.createElement("div");
modTitle.innerHTML = `
<div style="
font-size:2.5em;
font-weight:800;
text-align:center;
color:#fff;
margin-bottom: 10px;
text-shadow: 0 2px 8px rgba(143,107,255,.3);
">Custom Module Manager</div>
<div style="
opacity:.7;
font-weight:600;
text-align:center;
font-size:1.05em;
color:rgba(255,255,255,.85);
">
Create and manage your custom modules.<br>
Refresh to update custom modules.
</div>
`;
const buttonGrid = document.createElement("div");
buttonGrid.className = "buttonGrid";
// Count modules to determine if we should center
// If you find a more optomized way please tell me
const updateButtonGrid = () => {
const moduleCount = (CookieHelper.getCookie('custom_modules_list') || []).length;
const buttonCount = moduleCount > 0 ? 3 : 3;
if (buttonCount <= 3) {
buttonGrid.classList.add('centered');
} else {
buttonGrid.classList.remove('centered');
}
};
const createBtn = document.createElement("button");
createBtn.className = "moduleBtn";
createBtn.innerHTML = `
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5">
<line x1="12" y1="5" x2="12" y2="19"></line>
<line x1="5" y1="12" x2="19" y2="12"></line>
</svg>
Create Module
`;
createBtn.onclick = async () => {
const { value: formValues, isDismissed } = await Sweetalert2.fire({
title: '<span>Create New Module</span><button class="helpBtn" id="help-btn" type="button">?</button>',
html:
'<input id="swal-name" class="swal2-input" placeholder="Module Name" style="margin-bottom: 10px;">' +
'<textarea id="swal-desc" class="swal2-textarea" placeholder="Description (optional)" style="height: 80px; margin-bottom: 10px;"></textarea>' +
'<select id="swal-type" class="swal2-select" style="background: #1a1625 !important; border: 1px solid #fff !important; color: rgba(255,255,255,.75) !important; padding: 10px 15px; border-radius: 8px; line-height: 1.6;"><option value="execute" style="background: #1a1625; color: #e0e7ff;">Execute Button</option><option value="toggle" style="background: #1a1625; color: #e0e7ff;">Toggle</option><option value="edit" style="background: #1a1625; color: #e0e7ff; margin-bottom: 10px;">Value Edit</option></select>' +
'<textarea id="swal-code" class="swal2-textarea" placeholder="JavaScript Code" style="height: 150px; font-family: monospace;"></textarea>',
focusConfirm: false,
width: '600px',
didOpen: () => {
const helpBtn = document.getElementById('help-btn');
if (helpBtn) {
helpBtn.addEventListener('click', (e) => {
e.preventDefault();
e.stopPropagation();
Sweetalert2.close();
showDocumentation();
});
}
},
preConfirm: () => {
const name = document.getElementById('swal-name').value;
const code = document.getElementById('swal-code').value;
if (!name || !code) {
Sweetalert2.showValidationMessage('Name and code are required');
return false;
}
return {
name: name,
description: document.getElementById('swal-desc').value,
type: document.getElementById('swal-type').value,
code: minifyJS(code)
};
}
});
if (formValues) {
const saved = CookieHelper.getCookie('custom_modules_list') || [];
saved.push(formValues);
CookieHelper.setCookie('custom_modules_list', saved);
updateButtonGrid();
refreshClearButton();
refreshCustomModulesUI();
Sweetalert2.fire('Success', 'Module created successfully', 'success');
}
};
const manageBtn = document.createElement("button");
manageBtn.className = "moduleBtn moduleManageBtn";
manageBtn.innerHTML = `
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5">
<path d="M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"></path>
<path d="M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"></path>
</svg>
Manage Modules
`;
manageBtn.onclick = () => {
showModuleManager();
};
const importBtn = document.createElement("button");
importBtn.className = "moduleBtn moduleSecondaryBtn";
importBtn.innerHTML = `
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5">
<path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"></path>
<polyline points="7 10 12 15 17 10"></polyline>
<line x1="12" y1="15" x2="12" y2="3"></line>
</svg>
Import
`;
importBtn.onclick = async () => {
const { value: code } = await Sweetalert2.fire({
title: 'Import Module(s)',
input: 'textarea',
inputPlaceholder: 'Paste your module JSON here...',
width: '600px',
inputAttributes: {
style: 'font-family: monospace; height: 200px;'
}
});
if (code) {
try {
const parsed = JSON.parse(code);
const saved = CookieHelper.getCookie('custom_modules_list') || [];
if (Array.isArray(parsed)) saved.push(...parsed);
else saved.push(parsed);
CookieHelper.setCookie('custom_modules_list', saved);
updateButtonGrid();
refreshClearButton();
Sweetalert2.fire('Success', 'Module(s) imported successfully', 'success');
refreshCustomModulesUI();
} catch (e) {
Sweetalert2.fire('Error', 'Invalid JSON format', 'error');
}
}
};
const exportBtn = document.createElement("button");
exportBtn.className = "moduleBtn moduleSecondaryBtn";
exportBtn.innerHTML = `
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5">
<path d="M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"></path>
<polyline points="17 8 12 3 7 8"></polyline>
<line x1="12" y1="3" x2="12" y2="15"></line>
</svg>
Export
`;
exportBtn.onclick = () => {
const modules = JSON.stringify(CookieHelper.getCookie('custom_modules_list') || []);
Sweetalert2.fire({
title: 'Export Your Modules',
input: 'textarea',
inputValue: modules,
width: '600px',
inputAttributes: {
style: 'font-family: monospace; height: 200px;',
readonly: true
},
showCancelButton: true,
confirmButtonText: 'Copy to Clipboard',
preConfirm: () => {
navigator.clipboard.writeText(modules);
return true;
}
}).then((result) => {
if (result.isConfirmed) {
Sweetalert2.fire('Copied', 'Modules copied to clipboard', 'success');
}
});
};
buttonGrid.append(createBtn, manageBtn, importBtn, exportBtn);
// Clear All button
const clearAllContainer = document.createElement("div");
clearAllContainer.className = "clearAllContainer";
const clearBtn = document.createElement("button");
clearBtn.className = "moduleBtn moduleDangerBtn clearAllBtn";
clearBtn.innerHTML = `
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5">
<polyline points="3 6 5 6 21 6"></polyline>
<path d="M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"></path>
</svg>
Clear All Modules
`;
clearBtn.onclick = async () => {
const result = await Sweetalert2.fire({
title: 'Delete All Modules?',
text: 'This action cannot be undone',
icon: 'warning',
showCancelButton: true,
confirmButtonColor: '#ef4444',
cancelButtonColor: '#4b5563',
confirmButtonText: 'Delete All'
});
if (result.isConfirmed) {
CookieHelper.setCookie('custom_modules_list', []);
updateButtonGrid();
clearAllContainer.style.display = 'none';
Sweetalert2.fire('Deleted', 'All modules have been removed', 'success');
}
};
function refreshClearButton() {
const modules = CookieHelper.getCookie('custom_modules_list') || [];
if (modules.length > 0) {
clearAllContainer.style.display = 'flex';
} else {
clearAllContainer.style.display = 'none';
}
}
clearAllContainer.appendChild(clearBtn);
function refreshCustomModulesUI() {
const customModules = CookieHelper.getCookie('custom_modules_list') || [];
const customCheats = customModules.map((module, index) => {
const defaultDescription = module.description || `Custom Module #${index + 1}`;
if (module.type === 'execute') {
return {
name: module.name,
description: defaultDescription,
run: createFunctionFromCode(module.code)
};
} else if (module.type === 'toggle') {
return {
name: module.name,
description: defaultDescription,
type: 'toggle',
enabled: false,
data: null,
run: createFunctionFromCode(module.code)
};
} else if (module.type === 'edit') {
return {
name: module.name,
description: defaultDescription,
inputs: [{
name: 'Value',
type: 'string'
}],
run: createFunctionFromCode(module.code, 'value')
};
}
});
cheats.custom_modules.cheats = customCheats;
// Rebuild the custom modules list in the UI
// Use the stored reference to the custom modules page
if (customModulesPageRef && customModulesCheatsList) {
// Clear existing cheats
customModulesCheatsList.innerHTML = '';
// Rebuild all custom module cheats
for (const cheat of customCheats) {
const cheatElement = document.createElement("div");
const cheatTop = document.createElement("div");
cheatTop.className = classes.cheatTop;
const cheatInfo = document.createElement("div");
cheatInfo.className = classes.cheatInfo;
const cheatName = document.createElement("span");
cheatName.innerText = cheat.name;
cheatName.className = classes.cheatName;
const cheatDescription = document.createElement("span");
cheatDescription.innerText = cheat.description;
cheatDescription.className = classes.cheatDescription;
cheatInfo.append(cheatName, cheatDescription);
cheatElement.append(cheatTop);
// Handle inputs if the cheat has them
const inputs = [];
if (Array.isArray(cheat.inputs)) {
const cheatInputs = document.createElement("div");
cheatInputs.className = classes.cheatInputs;
for (const input of cheat.inputs) {
const inputElement = document.createElement("div");
const inputName = document.createElement("span");
inputName.innerText = input.name;
inputElement.append(inputName);
cheatInputs.append(inputElement);
if (input.type == "options") {
const inputField = document.createElement("select");
inputField.dataset[datasets.type] = "options";
inputElement.append(inputField);
inputs.push(inputField);
let curField = inputField;
const updateOptions = () => {
let choose = input.options;
const newInputField = document.createElement("select");
newInputField.dataset[datasets.type] = "options";
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
curField = newInputField;
if (typeof choose == "function")
try {
choose = choose();
} catch {
choose = []
}
if (choose instanceof Promise) {
const waiting = document.createElement("option");
waiting.value = '""';
waiting.innerHTML = "Loading Options...";
curField.append(waiting);
choose.then((choices) => {
if (choices?.length > 0) {
curField.innerHTML = "";
for (const choice of choices) {
const option = document.createElement("option");
option.value = JSON.stringify(choice?.value ?? choice);
option.innerHTML = choice?.name || choice;
curField.append(option);
}
} else {
const newInputField = document.createElement("input");
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
newInputField.dataset[datasets.type] = "string";
newInputField.placeholder = input.name;
curField = newInputField;
}
});
} else {
if (choose?.length > 0) {
for (const choice of choose) {
const option = document.createElement("option");
option.value = JSON.stringify(choice?.value ?? choice);
option.innerHTML = choice?.name || choice;
curField.append(option);
}
} else {
const newInputField = document.createElement("input");
inputs[inputs.indexOf(curField)] = newInputField;
curField.replaceWith(newInputField);
newInputField.dataset[datasets.type] = "string";
newInputField.placeholder = input.name;
curField = newInputField;
}
}
};
updateOptions();
} else {
const inputField = document.createElement("input");
inputField.dataset[datasets.type] = input.type;
if (input.type == "number") {
inputField.type = "number";
inputField.min = input.min;
inputField.max = input.max;
inputField.value = input.value || (input.min ?? 0);
}
inputField.placeholder = input.name;
inputElement.append(inputField);
inputs.push(inputField);
}
}
cheatElement.append(cheatInputs);
}
cheatTop.append(cheatInfo);
const runButton = document.createElement("div");
runButton.className = classes.runCheat;
if (cheat.type == "toggle") {
runButton.innerText = "Toggle On";
runButton.classList.add(classes.toggleCheat);
} else {
runButton.innerText = "Execute";
}
runButton.onclick = () => {
try {
cheat.run.apply(
cheat,
inputs.map((x) => (x.dataset[datasets.type] == "number" ? parseFloat("0" + x.value) : x.dataset[datasets.type] == "options" ? JSON.parse(x.value) : x.value))
);
if (cheat.type == "toggle") {
cheat.enabled = !cheat.enabled;
runButton.innerText = "Toggle " + (cheat.enabled ? "Off" : "On");
runButton.classList.toggle(classes.active, cheat.enabled);
Logs.addLog(`Toggled "${cheat.name}" ${cheat.enabled ? "on" : "off"}`, cheat.enabled ? "var(--toggleOn)" : "var(--toggleOff)");
} else {
Logs.addLog(`Ran "${cheat.name}"`, "var(--highlight)");
}
} catch (err) {
Logs.addLog(`Error running "${cheat.name}": ${err.message}`, "var(--error)");
}
};
cheatTop.append(runButton);
customModulesCheatsList.append(cheatElement);
}
}
}
// Documentation function
function showDocumentation(editIndex = null) {
const docHTML = `
<div class="docContainer">
<div class="docSection">
<div class="docTitle">
<svg width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
<path d="M4 19.5A2.5 2.5 0 0 1 6.5 17H20"></path>
<path d="M6.5 2H20v20H6.5A2.5 2.5 0 0 1 4 19.5v-15A2.5 2.5 0 0 1 6.5 2z"></path>
</svg>
Custom Module Documentation
</div>
<div class="docText">
Learn how to create custom modules for your cheat menu. There are three types of modules available:
</div>
</div>
<div class="docSection">
<div class="docSubtitle">1. Execute Button</div>
<div class="docText">
A simple button that runs code once when clicked. Perfect for one-time actions.
</div>
<div class="docText"><span class="docHighlight">Key points:</span></div>
<ul class="docList">
<li>Code runs immediately when button is clicked</li>
<li>No state management needed</li>
<li>Use for instant actions like toggling dark mode or showing alerts</li>
</ul>
<div class="docCode">
// Example: Toggle Dark Mode
function() {
let darkMode = document.getElementById('nightify');
if (darkMode) {
darkMode.remove();
} else {
let style = document.createElement('style');
style.id = 'nightify';
style.textContent = 'html { filter: invert(100%) hue-rotate(180deg); }';
document.head.appendChild(style);
}
}</div>
</div>
<div class="docSection">
<div class="docSubtitle">2. Toggle</div>
<div class="docText">
A button that can be turned on and off. Great for continuous actions or intervals.
</div>
<div class="docText"><span class="docHighlight">Important properties:</span></div>
<ul class="docList">
<li><span class="docHighlight">this.enabled</span> - Boolean indicating if toggle is on/off</li>
<li><span class="docHighlight">this.data</span> - Store data like intervals or timers</li>
<li>Check <span class="docHighlight">this.enabled</span> to determine current state</li>
<li>Set <span class="docHighlight">this.enabled</span> to true when turning on</li>
<li>Set <span class="docHighlight">this.enabled</span> to false when turning off</li>
<li>Clean up intervals/timers when disabled</li>
</ul>
<div class="docCode">
// Example: Auto Answer Toggle
function() {
if (!this.enabled) {
// Turn ON
this.enabled = true;
this.data = setInterval(() => {
// Your repeated code here
console.log('Running...');
}, 100);
} else {
// Turn OFF
this.enabled = false;
clearInterval(this.data);
this.data = null;
}
}</div>
</div>
<div class="docSection">
<div class="docSubtitle">3. Value Edit</div>
<div class="docText">
A module that accepts user input before running. Perfect for setting custom values.
</div>
<div class="docText"><span class="docHighlight">Usage:</span></div>
<ul class="docList">
<li><span class="docHighlight">function(parameterName)</span> - Your function receives the user's input as a parameter</li>
<li><span class="docHighlight">parameterName</span> - Can be any name you choose (e.g., amount, value, number)</li>
<li>User enters a value in a prompt before the module executes</li>
<li>The entered value is passed directly to your function</li>
</ul>
<div class="docText"><span class="docHighlight">Key points:</span></div>
<ul class="docList">
<li>Great for setting game values, amounts, or custom settings</li>
<li>Parameter can be used anywhere in your function code</li>
<li>Input type is determined by module configuration (number, string, etc.)</li>
</ul>
<div class="docCode">
// Example: Set Crypto Amount
function(amount) {
let stateNode = getStateNode();
stateNode.setState({
crypto: amount,
crypto2: amount
});
stateNode.props.liveGameController.setVal({
path: \`c/\${stateNode.props.client.name}/cr\`,
val: amount
});
}</div>
</div>
<div class="docSection">
<div class="docSubtitle">Code Format Options</div>
<div class="docText">
You can write your code in any of these formats:
</div>
<ul class="docList">
<li><span class="docHighlight">Function declaration:</span> function() { /* code */ } or function(param) { /* code */ }</li>
<li><span class="docHighlight">Arrow function:</span> () => { /* code */ } or (param) => { /* code */ }</li>
<li><span class="docHighlight">Function body only:</span> Just write the code without function wrapper</li>
</ul>
<div class="docText">
All three formats work equally well - choose whichever you prefer!
</div>
</div>
<div class="docSection">
<div class="docSubtitle">Tips & Best Practices</div>
<ul class="docList">
<li>Test your modules in a safe environment first</li>
<li>Always clean up intervals and timers in toggle modules</li>
<li>Use descriptive names and descriptions for your modules</li>
<li>For toggles, always check <span class="docHighlight">this.enabled</span> first</li>
<li>Store interval IDs in <span class="docHighlight">this.data</span> for toggle modules</li>
</ul>
</div>
</div>
`;
Sweetalert2.fire({
title: 'Module Documentation',
html: docHTML,
width: '750px',
showConfirmButton: true,
confirmButtonText: 'Back',
confirmButtonColor: '#6366f1',
customClass: {
popup: 'doc-popup'
}
}).then(() => {
if (editIndex !== null) {
editModule(editIndex);
} else {
createBtn.click();
}
});
}
function showModuleManager() {
const modules = CookieHelper.getCookie('custom_modules_list') || [];
if (modules.length === 0) {
Sweetalert2.fire({
title: 'No Modules',
text: 'You haven\'t created any modules yet',
icon: 'info',
confirmButtonColor: '#6366f1'
});
return;
}
let moduleListHTML = '<div style="max-height: 450px; overflow-y: auto; padding-right: 8px;">';
modules.forEach((module, index) => {
const escapedName = module.name.replace(/</g, '<').replace(/>/g, '>');
const escapedDesc = (module.description || 'No description').replace(/</g, '<').replace(/>/g, '>');
moduleListHTML += `
<div class="moduleItemCard">
<div class="moduleItemInfo">
<div class="moduleItemTitle">${escapedName}</div>
<div class="moduleItemDesc">${escapedDesc}</div>
<span class="moduleItemType">${module.type}</span>
</div>
<div class="moduleItemActions">
<button class="moduleActionBtn moduleEditBtn" data-index="${index}" data-action="edit">
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2.5">
<path d="M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"></path>
<path d="M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"></path>
</svg>
</button>
<button class="moduleActionBtn moduleDeleteBtn" data-index="${index}" data-action="delete">
<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="2.5">
<polyline points="3 6 5 6 21 6"></polyline>
<path d="M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"></path>
</svg>
</button>
</div>
</div>
`;
});
moduleListHTML += '</div>';
Sweetalert2.fire({
title: 'Manage Modules',
html: moduleListHTML,
width: '700px',
showConfirmButton: false,
showCloseButton: true,
confirmButtonColor: '#6366f1',
didOpen: () => {
const actionBtns = document.querySelectorAll('.moduleActionBtn');
actionBtns.forEach(btn => {
btn.addEventListener('click', (e) => {
e.stopPropagation();
const index = parseInt(btn.dataset.index);
const action = btn.dataset.action;
if (action === 'edit') {
editModule(index);
} else if (action === 'delete') {
deleteModule(index);
}
});
});
}
});
}
async function editModule(index) {
const modules = CookieHelper.getCookie('custom_modules_list') || [];
const module = modules[index];
const { value: formValues, isDismissed } = await Sweetalert2.fire({
title: '<span>Edit Module</span><button class="helpBtn" id="help-btn-edit" type="button">?</button>',
html:
`<input id="swal-name" class="swal2-input" placeholder="Module Name" value="${module.name.replace(/"/g, '"')}" style="margin-bottom: 10px;">` +
`<textarea id="swal-desc" class="swal2-textarea" placeholder="Description (optional)" style="height: 80px; margin-bottom: 10px;">${module.description || ''}</textarea>` +
`<select id="swal-type" class="swal2-select" style="margin-bottom: 10px;">
<option value="execute" ${module.type === 'execute' ? 'selected' : ''}>Execute Button</option>
<option value="toggle" ${module.type === 'toggle' ? 'selected' : ''}>Toggle</option>
<option value="edit" ${module.type === 'edit' ? 'selected' : ''}>Value Edit</option>
</select>` +
`<textarea id="swal-code" class="swal2-textarea" placeholder="JavaScript Code" style="height: 150px; font-family: monospace;">${module.code}</textarea>`,
focusConfirm: false,
width: '600px',
confirmButtonColor: '#6366f1',
didOpen: () => {
const helpBtn = document.getElementById('help-btn-edit');
if (helpBtn) {
helpBtn.addEventListener('click', (e) => {
e.preventDefault();
e.stopPropagation();
Sweetalert2.close();
showDocumentation(index);
});
}
},
preConfirm: () => {
const name = document.getElementById('swal-name').value;
const code = document.getElementById('swal-code').value;
if (!name || !code) {
Sweetalert2.showValidationMessage('Name and code are required');
return false;
}
return {
name: name,
description: document.getElementById('swal-desc').value,
type: document.getElementById('swal-type').value,
code: minifyJS(code) // Minify code before saving
};
}
});
if (formValues) {
modules[index] = formValues;
CookieHelper.setCookie('custom_modules_list', modules);
// Refresh the modules in the gamemodes list
refreshCustomModulesUI();
await Sweetalert2.fire({
title: 'Updated',
text: 'Module updated successfully',
icon: 'success',
confirmButtonColor: '#6366f1'
});
showModuleManager();
} else if (isDismissed) {
showModuleManager();
}
}
async function deleteModule(index) {
const modules = CookieHelper.getCookie('custom_modules_list') || [];
const module = modules[index];
const confirm = await Sweetalert2.fire({
title: 'Delete Module?',
text: `Are you sure you want to delete "${module.name}"?`,
icon: 'warning',
showCancelButton: true,
confirmButtonColor: '#ef4444',
cancelButtonColor: '#4b5563',
confirmButtonText: 'Delete'
});
if (confirm.isConfirmed) {
modules.splice(index, 1);
CookieHelper.setCookie('custom_modules_list', modules);
// Refresh the modules in the gamemodes list
refreshCustomModulesUI();
updateButtonGrid();
refreshClearButton();
await Sweetalert2.fire({
title: 'Deleted',
text: 'Module has been removed',
icon: 'success',
confirmButtonColor: '#6366f1'
});
showModuleManager();
} else {
showModuleManager();
}
}
updateButtonGrid();
// Only show clear button if modules exist
refreshClearButton();
modulePage.append(modTitle, buttonGrid, clearAllContainer);
const licenseMessage = document.createElement("div");
licenseMessage.className = classes.licenseMessage;
licenseMessage.innerHTML = `<i class="fas fa-file-alt" style="line-height: 1;aspect-ratio: 1 / 1;height: 20px;display: inline-grid;place-items: center;"></i> This script is licensed under <a style="color: var(--highlight);" target="_blank" href="https://www.gnu.org/licenses/agpl-3.0.en.html">AGPL-3.0</a>, read more <a style="color: var(--highlight);" target="_blank" href="https://github.com/Blooket-Council/Blooket-Cheats?tab=readme-ov-file#licensing">here</a>.<br>`;
const copyrightTag = document.createElement("span");
copyrightTag.className = classes.copyrightTag;
copyrightTag.innerText = `Copyright © ${new Date().getFullYear()} Tony-the-best`;
const codingCredits = document.createElement("ul");
codingCredits.className = classes.codingCredits;
codingCredits.append(createCredit("Owner", "Tony-the-best"));
codingCredits.append(createCredit("Full GUI Dev", "Cathead+landsedge"));
codingCredits.append(createCredit("Module Dev", "redhorse26"));
codingCredits.append(createCredit("Design+Module Dev", "Lil Skittle"));
codingCredits.append(createCredit("Contributor", "DannyDan"));
codingCredits.append(createCredit("Original Blooket Cheats", 'gliz <i class="fas fa-long-arrow-alt-right"></i> Minesraft2 <i class="fas fa-long-arrow-alt-right"></i> 05Konz'));
const creditLinks = document.createElement("ul");
creditLinks.className = classes.creditLinks;
creditLinks.append(createCredit("Our Github", '<a target="_blank" href="https://github.com/Tony-the-the-best/blooket-gui">X-GUI CHEATS/GITHUB</a>'));
creditLinks.append(createCredit("Our Website", '<a target="_blank" href="https://xgui-client.github.io">More Info/Website</a>'));
creditLinks.append(createCredit("Discord", '<a target="_blank" href="https://discord.gg/A7CRUz8vFR">JOIN THE SERVER</a>'));
function parseTime(d) {
const hour = d.getHours() % 12 == 0 ? 12 : d.getHours() % 12;
const minutes = d.getMinutes().toString().padStart(2, "0");
return `${hour}:${minutes} ${d.getHours() >= 12 ? "PM" : "AM"}`;
}
function parseDate(d) {
const month = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"][d.getMonth()];
return `${month} ${d.getDate()}${getOrdinal(d.getDate())}, ${d.getFullYear()} - ${parseTime(d)}`;
}
const uploadDates = document.createElement("ul");
uploadDates.className = classes.uploadDates;
try {
let currentDate = new Date(null),
latestDate = new Date(null);
if (latestProcess != -1) uploadDates.append(createCredit("", parseDate(null)));
if (currentDate < latestDate) {
const warning = document.createElement("");
warning.className = classes.warning;
warning.innerText = "";
uploadDates.append(warning);
}
} catch {
const warning = document.createElement("");
warning.className = classes.warning;
warning.innerText = "";
uploadDates.append(warning);
}
creditsPage.append(licenseMessage, codingCredits, creditLinks, uploadDates, copyrightTag);
function getOrdinal(n) {
if (n % 10 == 1 && n % 100 != 11) return "st";
if (n % 10 == 2 && n % 100 != 12) return "nd";
if (n % 10 == 3 && n % 100 != 13) return "rd";
return "th";
}
function createCredit(contribution, html) {
const listItem = document.createElement("li");
const contributionText = document.createElement("strong");
contributionText.innerText = contribution + ":";
const right = document.createElement("span");
right.innerHTML = html;
listItem.append(contributionText, right);
return listItem;
}
// --- Create Centered, Large Ping Display ---
const pingDisplay = document.createElement("div");
pingDisplay.id = "xguiPingDisplay";
pingDisplay.style.cssText = `
margin-top: 40px;
text-align: center;
font-size: 1.4em;
font-weight: 700;
color: var(--highlight);
font-family: Nunito, sans-serif;
width: 100%;
`;
pingDisplay.innerText = "Server Ping: Calculating...";
creditsPage.appendChild(pingDisplay);
function updatePing() {
const start = performance.now();
const img = new Image();
img.onload = () => {
const latency = Math.round(performance.now() - start);
pingDisplay.innerText = `Server Ping: ${latency} ms`;
};
img.onerror = () => {
pingDisplay.innerText = "Server Ping: Offline";
};
img.src = "https://ac.blooket.com/dashclassic/favicon.ico?cb=" + Date.now();
}
updatePing();
setInterval(updatePing, 5000);
// ===== RESET GUI POSITION BUTTON =====
if (!document.querySelector("#resetGuiBtn")) {
const resetGuiBtn = document.createElement("button");
resetGuiBtn.id = "resetGuiBtn";
resetGuiBtn.textContent = "Reset GUI Position";
Object.assign(resetGuiBtn.style, {
display: "block", // makes centering easier
margin: "10px auto 0 auto", // centers the button horizontally
padding: "10px 20px",
borderRadius: "12px",
border: "none",
cursor: "pointer",
background: "linear-gradient(135deg, #8A2BE2, #4B0082)", // gradient for modern look
color: "#fff",
fontWeight: "700",
fontSize: "14px",
boxShadow: "0 4px 10px rgba(0,0,0,0.25)", // subtle shadow
transition: "all 0.3s ease", // smooth hover effect
});
// Hover effect
resetGuiBtn.onmouseenter = () => {
resetGuiBtn.style.transform = "scale(1.05)";
resetGuiBtn.style.boxShadow = "0 6px 14px rgba(0,0,0,0.3)";
};
resetGuiBtn.onmouseleave = () => {
resetGuiBtn.style.transform = "scale(1)";
resetGuiBtn.style.boxShadow = "0 4px 10px rgba(0,0,0,0.25)";
};
resetGuiBtn.onclick = () => {
// center GUI
gui.style.left = (window.innerWidth / 2 - 400) + "px";
gui.style.top = (window.innerHeight / 2 - 250) + "px";
// un-minimize if needed
if (minimizeControl?.minimized) {
minimizeControl.onclick();
}
// clear saved position
document.cookie =
"xgui_state_v4=; path=/; domain=.blooket.com; expires=Thu, 01 Jan 1970 00:00:00 GMT";
};
// place directly under ping display
pingDisplay.parentElement.appendChild(resetGuiBtn);
}
const settingsPage = document.createElement("div");
settingsPage.className = classes.noScroll + " " + classes.settingsPage;
const searchResultSeparator = document.createElement("div");
searchResultSeparator.onclick = () => path.push("Settings", settingsPage);
searchResultSeparator.className = classes.searchResultSeparator;
searchResultSeparator.innerText = "Settings";
searchResultSeparator.dataset[datasets.name] = "settings";
gamemodeResults.settings = searchResultSeparator;
searchResults.append(searchResultSeparator);
const settingRefresh = [];
function addSetting(name, description, input, onUpdate) {
const settingElement = document.createElement("div");
const searchResult = document.createElement("div");
searchResult.className = classes.searchResult;
const searchResultInfo = document.createElement("div");
searchResultInfo.className = classes.searchResultInfo;
const searchResultName = document.createElement("div");
searchResultName.className = classes.searchResultName;
searchResult.dataset[datasets.name] = (searchResultName.innerText = name).toLowerCase();
searchResult.dataset[datasets.mode] = "settings";
const searchResultDescription = document.createElement("div");
searchResultDescription.className = classes.searchResultDescription;
searchResult.dataset[datasets.description] = (searchResultDescription.innerText = description).toLowerCase();
searchResultInfo.append(searchResultName, searchResultDescription);
searchResult.onclick = () => {
path.push(name, settingsPage);
settingElement.scrollIntoView();
settingElement.animate(
[{
color: "var(--textColor)",
textShadow: "0 0 0px var(--highlight)",
},
{
color: "var(--highlight)",
textShadow: "0 0 5px var(--highlight)",
offset: 0.25,
},
{
color: "var(--textColor)",
textShadow: "0 0 0px var(--highlight)",
},
],
1500
);
};
searchResult.append(searchResultInfo);
searchResults.append(searchResult);
const settingTop = document.createElement("div");
settingTop.className = classes.cheatTop;
const settingInfo = document.createElement("div");
settingInfo.className = classes.cheatInfo;
const settingName = document.createElement("span");
settingName.innerText = name;
settingName.className = classes.cheatName;
const settingDescription = document.createElement("span");
settingDescription.innerText = description;
settingDescription.className = classes.cheatDescription;
settingInfo.append(settingName, settingDescription);
settingElement.append(settingTop);
const settingInputs = document.createElement("div");
settingInputs.className = classes.cheatInputs;
const inputElement = document.createElement("div");
const inputName = document.createElement("span");
inputName.innerText = input.name;
inputElement.append(inputName);
settingInputs.append(inputElement);
let inputField = document.createElement("input");
inputField.dataset[datasets.type] = input.type;
if (input.type == "keybind") {
inputField.readOnly = true;
let locked = false;
inputField.data = input.data;
inputField.onclick = async () => {
if (locked) return;
inputField.value = "Waiting for input...";
locked = true;
inputField.data = await input.listen((e) => (inputField.value = e + "..."));
locked = false;
inputField.value = inputField.value.slice(0, -3);
};
(settingRefresh[settingRefresh.length] = () => (inputField.value = input.value()))();
} else if (input.type == "options") {
inputField = document.createElement("select");
inputField.dataset[datasets.type] = "options";
const defaultOption = document.createElement("option");
defaultOption.value = "{}";
defaultOption.innerHTML = "Select a Theme";
(settingRefresh[settingRefresh.length] = () => (defaultOption.selected = true))();
inputField.append(defaultOption);
for (const choice of input.options) {
const option = document.createElement("option");
option.value = JSON.stringify(choice?.value ?? choice);
option.innerHTML = choice?.name || choice;
inputField.append(option);
}
} else if (input.type == "toggle") {
// Handle toggle type - no input field needed, hide the inputs section
inputField = null;
settingInputs.style.display = "none";
} else {
if (input.type == "number") {
inputField.type = "number";
inputField.min = input.min;
inputField.max = input.max;
}
(settingRefresh[settingRefresh.length] = () => (inputField.value = input.value()))();
inputField.placeholder = input.name;
}
if (inputField) {
inputElement.append(inputField);
}
settingElement.append(settingInputs);
settingTop.append(settingInfo);
const runButton = document.createElement("div");
runButton.className = classes.runCheat;
if (input.type == "toggle") {
runButton.classList.add(classes.toggleCheat);
runButton.innerText = input.enabled ? "Toggle Off" : "Toggle On";
runButton.classList.toggle(classes.active, input.enabled);
runButton.style.width = "20%";
runButton.style.margin = "10px auto";
runButton.onclick = () => {
input.enabled = !input.enabled;
runButton.innerText = input.enabled ? "Toggle Off" : "Toggle On";
runButton.classList.toggle(classes.active, input.enabled);
onUpdate(input.enabled);
};
(settingRefresh[settingRefresh.length] = () => {
const currentEnabled = input.value();
input.enabled = currentEnabled;
runButton.innerText = currentEnabled ? "Toggle Off" : "Toggle On";
runButton.classList.toggle(classes.active, currentEnabled);
})();
} else {
runButton.innerText = "Update";
runButton.onclick = () =>
onUpdate(inputField.dataset[datasets.type] == "number" ? parseFloat("0" + inputField.value) : inputField.dataset[datasets.type] == "options" ? JSON.parse(inputField.value) : inputField.data ?? inputField.value);
}
settingTop.append(runButton);
settingsPage.append(settingElement);
}
function setCookie(name, value, days = 365) {
const expireDate = new Date();
expireDate.setTime(expireDate.getTime() + (days * 24 * 60 * 60 * 1000));
document.cookie = `${name}=${encodeURIComponent(value)}; domain=.blooket.com; expires=${expireDate.toUTCString()}; path=/`;
}
settingsPage.onPath = () => settingRefresh.forEach((x) => x());
addSetting(
"Hide Keybind",
"Shortcut to hide to GUI", {
type: "keybind",
name: "Shortcut",
data: defaultHideKey,
value: () => parseKeybind(Settings.data.hideKey),
listen: (change) => createKeybindListener((keys) => change(parseKeybind(keys))),
},
(x) => {
Settings.setItem("hideKey", x);
}
);
addSetting(
"Close Keybind",
"Shortcut to disable all toggles and close GUI", {
type: "keybind",
name: "Shortcut",
data: defaultCloseKey,
value: () => parseKeybind(Settings.data.closeKey),
listen: (change) => createKeybindListener((keys) => change(parseKeybind(keys))),
},
(x) => {
Settings.setItem("closeKey", x);
}
);
addSetting(
"Toggle Animations",
"Enable or disable smooth animations", {
type: "toggle",
name: "Animations",
enabled: (() => {
const cookieValue = getCookie("animationsEnabled");
return cookieValue === null ? true : cookieValue === "true";
})(),
value: () => {
const cookieValue = getCookie("animationsEnabled");
return cookieValue === null ? true : cookieValue === "true";
},
},
(enabled) => {
setCookie("animationsEnabled", enabled.toString(), 365);
window.xguiAnimationsEnabled = enabled;
}
);
addSetting(
"Toggle Sweet Alerts",
"Toggles sweet alerts on and off", {
type: "toggle",
name: "Sweet Alerts",
enabled: true,
value: () => {
const cookieValue = getCookie("sweetAlertsEnabled");
return cookieValue === null ? true : cookieValue === "true";
},
},
(enabled) => {
setCookie("sweetAlertsEnabled", enabled.toString(), 365);
}
);
addSetting(
"Theme",
"A preset look for X-GUI", {
type: "options",
name: "Preset",
options: [{
name: "Cyber Blue",
value: {
highlight: "#00bfff",
highlight2: "#0077aa",
background: "radial-gradient(circle at top, #0f2027, #000000)",
background2: "#020b14",
toggleOn: "#00ffcc",
toggleOff: "#ff4d4d",
textColor: "#e6f7ff",
textColor2: "#00bfff",
},
},
{
name: "Inferno",
value: {
highlight: "#ff6a00",
highlight2: "#c0392b",
background: "linear-gradient(135deg, #2b0000, #7a1c00)",
background2: "#3a0f0f",
toggleOn: "#ff9f1a",
toggleOff: "#5c1a1a",
textColor: "#fff2e6",
textColor2: "#ff6a00",
},
},
{
name: "Emerald Night",
value: {
highlight: "#2ecc71",
highlight2: "#1e824c",
background: "linear-gradient(180deg, #051f14, #020b08)",
background2: "#03140c",
toggleOn: "#2ecc71",
toggleOff: "#8b1e1e",
textColor: "#eafff3",
textColor2: "#2ecc71",
},
},
{
name: "Midnight Purple",
value: {
highlight: "#8e44ad",
highlight2: "#5e3370",
background: "linear-gradient(160deg, #120018, #000000)",
background2: "#1a0022",
toggleOn: "#bb6bd9",
toggleOff: "#7a1a1a",
textColor: "#f5e6ff",
textColor2: "#bb6bd9",
},
},
{
name: "Frozen Ice",
value: {
highlight: "#7ed6df",
highlight2: "#22a6b3",
background: "linear-gradient(180deg, #e8f9ff, #b8ecff)",
background2: "#dff6ff",
toggleOn: "#22a6b3",
toggleOff: "#be2edd",
textColor: "#003344",
textColor2: "#22a6b3",
},
},
{
name: "Crimson Void",
value: {
highlight: "#e74c3c",
highlight2: "#96281b",
background: "radial-gradient(circle, #2b0000, #000000)",
background2: "#1a0000",
toggleOn: "#ff7675",
toggleOff: "#3d0000",
textColor: "#ffecec",
textColor2: "#e74c3c",
},
},
{
name: "Matrix",
value: {
highlight: "#00ff41",
highlight2: "#00aa2a",
background: "radial-gradient(circle, #003300, #000000)",
background2: "#001a00",
toggleOn: "#00ff41",
toggleOff: "#660000",
textColor: "#ccffcc",
textColor2: "#00ff41",
},
},
{
name: "Sunset Vapor",
value: {
highlight: "#ff77aa",
highlight2: "#ffb347",
background: "linear-gradient(135deg, #ff5f6d, #845ec2)",
background2: "#2a1a40",
toggleOn: "#ffb347",
toggleOff: "#5a1a1a",
textColor: "#fff0f7",
textColor2: "#ff77aa",
},
},
{
name: "Neon Purple",
value: {
highlight: "#9a49aa",
highlight2: "#7a039d",
background: "rgb(11, 194, 207)",
background2: "rgb(64, 17, 95)",
toggleOn: "#47A547",
toggleOff: "#A02626",
textColor: "white",
textColor2: "#9a49aa",
},
},
{
name: "Landscapes (Random)",
value: {
highlight: "rgba(0,0,0,0.3)",
highlight2: "rgba(0,0,0,0.3)",
background: "url(https://source.unsplash.com/1600x900/?landscape)",
background2: "linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.3))",
toggleOn: "linear-gradient(rgba(0,128,0,0.3), rgba(0,128,0,0.3))",
toggleOff: "linear-gradient(rgba(225,0,0,0.3), rgba(225,0,0,0.3))",
textColor: "white",
textColor2: "white",
},
},
{
name: "Blacket",
value: {
highlight: "#2f2f2f",
highlight2: "#3f3f3f",
background: "#4f4f4f",
background2: "#2f2f2f",
toggleOn: "#00c20c",
toggleOff: "#eb6234",
textColor: "white",
textColor2: "white",
},
},
{
name: "Ploopit",
value: {
highlight: "#204DD0",
highlight2: "#3C75F5",
background: "url(https://i.ibb.co/6vvdq3f/ploopit.png)",
background2: "#3C75F5",
toggleOn: "#47A547",
toggleOff: "#A02626",
textColor: "white",
textColor2: "#3C75F5",
},
},
{
name: "Midnight Bloom",
value: {
highlight: "#bb2d5b",
highlight2: "#682c44",
background: "linear-gradient(135deg, #1b1b2f, #2a2a45)",
background2: "#3e3e5c",
toggleOn: "#bb2d5b",
toggleOff: "#682c44",
textColor: "#e0e0e0",
textColor2: "#bb2d5b",
},
},
{
name: "Silver Horizon",
value: {
highlight: "#d1d1d1",
highlight2: "#b0b0b0",
background: "linear-gradient(135deg, #4e4e5d, #2f2f38)",
background2: "#3c3c44",
toggleOn: "#d1d1d1",
toggleOff: "#5a5a60",
textColor: "#ffffff",
textColor2: "#d1d1d1",
},
},
{
name: "Deep Ocean",
value: {
highlight: "#006994",
highlight2: "#003b57",
background: "linear-gradient(180deg, #003b57, #011c2a)",
background2: "#002433",
toggleOn: "#006994",
toggleOff: "#004d6a",
textColor: "#cce7ff",
textColor2: "#006994",
},
},
{
name: "Rustic Copper",
value: {
highlight: "#a65c5c",
highlight2: "#7b4b4b",
background: "linear-gradient(135deg, #e57c73, #7b4b4b)",
background2: "#9e6e6e",
toggleOn: "#a65c5c",
toggleOff: "#5e2f2f",
textColor: "#ffffff",
textColor2: "#a65c5c",
},
},
{
name: "Frostbite",
value: {
highlight: "#85c7e0",
highlight2: "#6d9db1",
background: "linear-gradient(135deg, #2a4d6f, #1f3e50)",
background2: "#3e5a70",
toggleOn: "#85c7e0",
toggleOff: "#3e5a70",
textColor: "#ffffff",
textColor2: "#85c7e0",
},
},
{
name: "Citrus Mist",
value: {
highlight: "#f6a500",
highlight2: "#f67f1e",
background: "linear-gradient(135deg, #f0a500, #ff6600)",
background2: "#d05f20",
toggleOn: "#f6a500",
toggleOff: "#a34317",
textColor: "#ffffff",
textColor2: "#f6a500",
},
},
{
name: "Mossy Forest",
value: {
highlight: "#728c5f",
highlight2: "#3d6c3d",
background: "linear-gradient(180deg, #3d6c3d, #2b4d2b)",
background2: "#4f7037",
toggleOn: "#728c5f",
toggleOff: "#4f7037",
textColor: "#ffffff",
textColor2: "#728c5f",
},
},
{
name: "Astral Journey",
value: {
highlight: "#a0a2d0",
highlight2: "#6b6c9f",
background: "linear-gradient(135deg, #2c3e5c, #1b2a3b)",
background2: "#3e4b72",
toggleOn: "#a0a2d0",
toggleOff: "#4d5176",
textColor: "#ffffff",
textColor2: "#a0a2d0",
},
},
{
name: "Crimson Ember",
value: {
highlight: "#ff4c4c",
highlight2: "#b73838",
background: "linear-gradient(135deg, #ff4c4c, #b73838)",
background2: "#8f3030",
toggleOn: "#ff4c4c",
toggleOff: "#8f3030",
textColor: "#ffffff",
textColor2: "#ff4c4c",
},
},
{
name: "Obsidian Wave",
value: {
highlight: "#4e5d6b",
highlight2: "#2c3e4f",
background: "linear-gradient(135deg, #2c3e4f, #1b2a35)",
background2: "#3e4b5a",
toggleOn: "#4e5d6b",
toggleOff: "#2c3e4f",
textColor: "#ffffff",
textColor2: "#4e5d6b",
},
},
{
name: "Twilight Ember",
value: {
highlight: "#ff7f50",
highlight2: "#f14d27",
background: "linear-gradient(135deg, #ff7f50, #f14d27)",
background2: "#d24020",
toggleOn: "#ff7f50",
toggleOff: "#d24020",
textColor: "#ffffff",
textColor2: "#ff7f50",
},
},
{
name: "Garnet Eclipse",
value: {
highlight: "#9b2d20",
highlight2: "#6b1f14",
background: "linear-gradient(135deg, #9b2d20, #6b1f14)",
background2: "#6f2923",
toggleOn: "#9b2d20",
toggleOff: "#6f2923",
textColor: "#ffffff",
textColor2: "#9b2d20",
},
},
{
name: "Sapphire Twilight",
value: {
highlight: "#0f4b73",
highlight2: "#006282",
background: "linear-gradient(135deg, #0f4b73, #006282)",
background2: "#003e5d",
toggleOn: "#0f4b73",
toggleOff: "#003e5d",
textColor: "#ffffff",
textColor2: "#0f4b73",
},
},
{
name: "Betastar",
value: {
highlight: "#282828",
highlight2: "gray",
background: "url(https://i.ibb.co/8bkDpCn/GIFMaker-me.gif)",
background2: "linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.3))",
toggleOn: "#013220",
toggleOff: "#9D0000",
textColor: "black",
textColor2: "black",
},
},
{
name: "Skool.lol",
value: {
highlight: "#36393e",
highlight2: "#1e2124",
background: "linear-gradient(90deg, rgba(104,45,140,1) 220px, rgba(237,30,121,1) 100%)",
background2: "#292929",
toggleOn: "#9c9a9a",
toggleOff: "#171717",
textColor: "white",
textColor2: "white",
},
},
{
name: "X-GUI ORIGINAL",
value: {
highlight: variables["--highlight"],
highlight2: variables["--highlight2"],
background: variables["--background"],
background2: variables["--background2"],
textColor: variables["--textColor"],
textColor2: variables["--textColor2"],
toggleOff: variables["--toggleOff"],
toggleOn: variables["--toggleOn"],
},
},
{
name: "Crypto Hack",
value: {
highlight: "rgb(88 175 88)",
toggleOn: "#0b601b",
background: "radial-gradient(#11581e,#041607)",
background2: "#1a1a1a",
toggleOff: "#A02626",
highlight2: "#49d149",
textColor2: "#49d149",
},
},
{
name: "Deceptive Dinos",
value: {
highlight: "#af8942",
toggleOn: "#2fb62f",
background: "radial-gradient(rgba(220, 184, 86, 0), rgba(220, 184, 86, 0.4)), url(https://ac.blooket.com/play/111cb7e0ee6607ac3d1a13d534c0e0f1.png), #ead49a",
background2: "radial-gradient(rgba(1,104,162,.6),rgba(24,55,110,.5)),radial-gradient(#2783b4 1.5px,#18376e 0) center / 24px 24px",
toggleOff: "#A02626",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#FFFFFF",
},
},
{
name: "Blook Rush",
value: {
highlight: "#888",
toggleOn: "#47A547",
background: "repeating-linear-gradient(45deg,white,white 8%,#e6e6e6 0,#e6e6e6 16%)",
background2: "#36c",
toggleOff: "#A02626",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#FFFFFF",
},
},
{
name: "Factory",
value: {
highlight: "#1563bf",
toggleOn: "rgb(75, 194, 46)",
background: "#3a3a3a",
background2: "#2d313d",
toggleOff: "#9a49aa",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#a5aabe",
},
},
{
name: "Cafe",
value: {
highlight: "#0bc2cf",
toggleOn: "#47A547",
background: "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",
background2: "rgb(64, 64, 64)",
toggleOff: "#A02626",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#ac7339",
textColor: "#FFFFFF",
},
},
{
name: "Tower of Doom",
value: {
highlight: "#9a49aa",
toggleOn: "#4bc22e",
background: "rgb(41 41 41)",
background2: "#404040",
toggleOff: "rgb(151, 15, 5)",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#9a49aa",
textColor: "#FFFFFF",
},
},
{
name: "Monster Brawl",
value: {
highlight: "#2966a6",
toggleOn: "#47A547",
background: "rgb(45, 51, 67)",
background2: "#374154",
toggleOff: "#A02626",
highlight2: "#264d99",
textColor2: "#264d99",
textColor: "#FFFFFF",
},
},
{
name: "Tower Defense 2",
value: {
highlight: "#40b1d8",
toggleOn: "#47A547",
background: "url(https://media.blooket.com/image/upload/v1676164454/Media/defense/backgroundTd1-02.svg) center / cover",
background2: "#293c82",
toggleOff: "#A02626",
highlight2: "rgb(0 0 0 / 25%)",
textColor2: "#a33c22",
textColor: "#FFFFFF",
},
},
],
},
(x) => {
Settings.setItem("theme", {
...Settings.data.theme,
...x
});
for (const prop in x) gui.style.setProperty(`--${prop}`, x[prop]);
path.updatePath();
}
);
addSetting("Highlight 1", "Hover color, sub-text color, button color, and input outlines", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--highlight")
}, (x) =>
gui.style.setProperty("--highlight", Settings.setItem("theme.highlight", x || variables["--highlight"]))
);
addSetting("Highlight 2", "Credits page's warning message color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--highlight2")
}, (x) =>
gui.style.setProperty("--highlight2", Settings.setItem("theme.highlight2", x || variables["--highlight2"]))
);
addSetting("Background", "Main GUI background color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--background")
}, (x) =>
gui.style.setProperty("--background", Settings.setItem("theme.background", x || variables["--background"]))
);
addSetting("Background 2", "Secondary GUI background color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--background2")
}, (x) =>
gui.style.setProperty("--background2", Settings.setItem("theme.background2", x || variables["--background2"]))
);
addSetting("Text Color", "Main text color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--textColor")
}, (x) =>
gui.style.setProperty("--textColor", Settings.setItem("theme.textColor", x || variables["--textColor"]))
);
addSetting("Text Color 2", "Credit page's contributor color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--textColor2")
}, (x) =>
gui.style.setProperty("--textColor2", Settings.setItem("theme.textColor2", x || variables["--textColor2"]))
);
addSetting("Toggle (On)", "Enabled toggle button color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--toggleOn")
}, (x) =>
gui.style.setProperty("--toggleOn", Settings.setItem("theme.toggleOn", x || variables["--toggleOn"]))
);
addSetting("Toggle (Off)", "Disabled toggle button color", {
type: "string",
name: "CSS Value",
value: () => gui.style.getPropertyValue("--toggleOff")
}, (x) =>
gui.style.setProperty("--toggleOff", Settings.setItem("theme.toggleOff", x || variables["--toggleOff"]))
);
const sidebarPaths = document.createElement("div");
sidebarPaths.className = classes.sidebarPaths;
function createSidebarPath(name, iconKey, page) {
const sidebarPath = document.createElement("div");
sidebarPath.className = classes.sidebarPath;
// Clean and consistent spacing
sidebarPath.style.display = "flex";
sidebarPath.style.alignItems = "center";
sidebarPath.style.gap = "12px";
sidebarPath.style.cursor = "pointer";
// Icon wrapper — matches your original 50×50 FA container
const iconWrapper = document.createElement("div");
iconWrapper.style.width = "50px";
iconWrapper.style.height = "50px";
iconWrapper.style.display = "flex";
iconWrapper.style.alignItems = "center";
iconWrapper.style.justifyContent = "center";
iconWrapper.style.flexShrink = "0";
iconWrapper.style.fontSize = "1.5em"; // 1.5em scaling matches FA behavior
// --- CSP-SAFE SVG ICON SET (OUTLINE STYLE) ---
const svgMap = {
search: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<circle cx="11" cy="11" r="7"/>
<line x1="16.5" y1="16.5" x2="21" y2="21"/>
</svg>`,
gamepad: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<path d="M19.07 1.29l-1.41 1.41 1.11 1.11-2.22 2.22-3.84-3.84-1.41 1.42 1.11 1.11L2.2 14.93l6.14 6.14 10.21-10.2 1.11 1.11 1.41-1.41-3.84-3.84 2.22-2.22 1.11 1.11 1.41-1.41-2.83-2.83z"/>
<line x1="1.29" y1="21.29" x2="4.22" y2="18.36"/>
<line x1="7.66" y1="16.34" x2="5.64" y2="14.32"/>
<line x1="9.48" y1="14.52" x2="7.05" y2="12.09"/>
<line x1="11.29" y1="12.71" x2="9.88" y2="11.29"/>
<line x1="13.11" y1="10.89" x2="11.7" y2="9.48"/>
</svg>
`,
star: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<path d="M12 2l3.2 6.7L22 9.3l-5 4.3L18.4 22 12 18.3 5.6 22 7 13.6 2 9.3l6.8-.6L12 2z"/>
</svg>`,
trophy: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<path d="M8 21h8M8 17v4M16 17v4"/>
<path d="M7 3h10v4a5 5 0 01-10 0V3z"/>
</svg>`,
alt: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<circle cx="5.8" cy="16.32" r="2.39"/>
<path d="M1.5,23.48V23a4.3,4.3,0,0,1,4.3-4.3h0A4.3,4.3,0,0,1,10.09,23v.48"/>
<circle cx="18.2" cy="3.91" r="2.39"/>
<path d="M13.91,11.07v-.48A4.29,4.29,0,0,1,18.2,6.3h0a4.29,4.29,0,0,1,4.3,4.29v.48"/>
<polyline points="15.7 15.72 18.68 12.75 21.66 15.72"/>
<path d="M18.68,13v2.86A5.73,5.73,0,0,1,13,21.57h0"/>
<polyline points="8.3 8.32 5.32 11.3 2.34 8.32"/>
<path d="M5.32,11.07V8.2a5.72,5.72,0,0,1,5.73-5.72h0"/>
</svg>
`,
client: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24"
width="1em" height="1em"
fill="none"
stroke="currentColor"
stroke-width="1.8"
stroke-linecap="round"
stroke-linejoin="round">
<!-- wrench head -->
<path d="M14.5 3a4.5 4.5 0 00-3.8 6.8l-7.3 7.3a2 2 0 102.8 2.8l7.3-7.3A4.5 4.5 0 0019.5 7l-3 3-4-4 3-3z"/>
</svg>
`,
editor: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24"
width="1em" height="1em"
fill="none"
stroke="currentColor"
stroke-width="1.8"
stroke-linecap="round"
stroke-linejoin="round">
<!-- Box -->
<rect x="3" y="3" width="18" height="18" rx="4" ry="4"/>
<!-- Eyes -->
<circle cx="8" cy="10" r="1.2"/>
<circle cx="16" cy="10" r="1.2"/>
<!-- Smile -->
<path d="M7 15c1.5 1.5 4.5 1.5 6 0"/>
</svg>
`,
terminal: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<polyline points="4 17 10 11 4 5"/>
<line x1="12" y1="19" x2="20" y2="19"/>
</svg>`,
// === NEW PERFECT OUTLINE COG ===
cog: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<circle cx="12" cy="12" r="3"/>
<path d="M13.7654 2.15224C13.3978 2 12.9319 2 12 2C11.0681 2 10.6022 2 10.2346 2.15224C9.74457 2.35523 9.35522 2.74458 9.15223 3.23463C9.05957 3.45834 9.0233 3.7185 9.00911 4.09799C8.98826 4.65568 8.70226 5.17189 8.21894 5.45093C7.73564 5.72996 7.14559 5.71954 6.65219 5.45876C6.31645 5.2813 6.07301 5.18262 5.83294 5.15102C5.30704 5.08178 4.77518 5.22429 4.35436 5.5472C4.03874 5.78938 3.80577 6.1929 3.33983 6.99993C2.87389 7.80697 2.64092 8.21048 2.58899 8.60491C2.51976 9.1308 2.66227 9.66266 2.98518 10.0835C3.13256 10.2756 3.3397 10.437 3.66119 10.639C4.1338 10.936 4.43789 11.4419 4.43786 12C4.43783 12.5581 4.13375 13.0639 3.66118 13.3608C3.33965 13.5629 3.13248 13.7244 2.98508 13.9165C2.66217 14.3373 2.51966 14.8691 2.5889 15.395C2.64082 15.7894 2.87379 16.193 3.33973 17C3.80568 17.807 4.03865 18.2106 4.35426 18.4527C4.77508 18.7756 5.30694 18.9181 5.83284 18.8489C6.07289 18.8173 6.31632 18.7186 6.65204 18.5412C7.14547 18.2804 7.73556 18.27 8.2189 18.549C8.70224 18.8281 8.98826 19.3443 9.00911 19.9021C9.02331 20.2815 9.05957 20.5417 9.15223 20.7654C9.35522 21.2554 9.74457 21.6448 10.2346 21.8478C10.6022 22 11.0681 22 12 22C12.9319 22 13.3978 22 13.7654 21.8478C14.2554 21.6448 14.6448 21.2554 14.8477 20.7654C14.9404 20.5417 14.9767 20.2815 14.9909 19.902C15.0117 19.3443 15.2977 18.8281 15.781 18.549C16.2643 18.2699 16.8544 18.2804 17.3479 18.5412C17.6836 18.7186 17.927 18.8172 18.167 18.8488C18.6929 18.9181 19.2248 18.7756 19.6456 18.4527C19.9612 18.2105 20.1942 17.807 20.6601 16.9999C21.1261 16.1929 21.3591 15.7894 21.411 15.395C21.4802 14.8691 21.3377 14.3372 21.0148 13.9164C20.8674 13.7243 20.6602 13.5628 20.3387 13.3608C19.8662 13.0639 19.5621 12.558 19.5621 11.9999C19.5621 11.4418 19.8662 10.9361 20.3387 10.6392C20.6603 10.4371 20.8675 10.2757 21.0149 10.0835C21.3378 9.66273 21.4803 9.13087 21.4111 8.60497C21.3592 8.21055 21.1262 7.80703 20.6602 7C20.1943 6.19297 19.9613 5.78945 19.6457 5.54727C19.2249 5.22436 18.693 5.08185 18.1671 5.15109C17.9271 5.18269 17.6837 5.28136 17.3479 5.4588C16.8545 5.71959 16.2644 5.73002 15.7811 5.45096C15.2977 5.17191 15.0117 4.65566 14.9909 4.09794C14.9767 3.71848 14.9404 3.45833 14.8477 3.23463C14.6448 2.74458 14.2554 2.35523 13.7654 2.15224Z"/>
</svg>
`,
mobile: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<rect x="7" y="2" width="10" height="20" rx="2"></rect>
<circle cx="12" cy="18" r="1" fill="currentColor"></circle>
</svg>`,
info: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<circle cx="12" cy="12" r="9"/>
<line x1="12" y1="11" x2="12" y2="17"/>
<circle cx="12" cy="8" r="0.5" fill="currentColor"/>
</svg>`,
// === NEW CHANGELOG SVG ===
changelog: `
<svg xmlns="http://www.w3.org/2000/svg"
width="1em" height="1em"
viewBox="0 0 24 24"
fill="none" stroke="currentColor"
stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round">
<rect x="3" y="3" width="14" height="18" rx="2"/>
<path d="M7 7h6M7 11h6M7 15h4"/>
<polyline points="17 3 21 3 21 7"/>
<line x1="21" y1="3" x2="17" y2="7"/>
</svg>
`,
default: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 24 24" width="1em" height="1em"
fill="currentColor">
<circle cx="12" cy="12" r="8"/>
</svg>`,
module: `
<svg xmlns="http://www.w3.org/2000/svg"
viewBox="0 0 16 16"
width="1em" height="1em"
fill="currentColor"
preserveAspectRatio="xMidYMid meet">
<path d="M8.01005 0.858582L6.01005 14.8586L7.98995 15.1414L9.98995 1.14142L8.01005 0.858582Z"></path>
<path d="M12.5 11.5L11.0858 10.0858L13.1716 8L11.0858 5.91422L12.5 4.5L16 8L12.5 11.5Z"></path>
<path d="M2.82843 8L4.91421 10.0858L3.5 11.5L0 8L3.5 4.5L4.91421 5.91422L2.82843 8Z"></path>
</svg>
`
};
iconWrapper.innerHTML = svgMap[iconKey] || svgMap.default;
const svg = iconWrapper.querySelector("svg");
if (svg) {
svg.style.display = "block";
}
const label = document.createElement("span");
label.innerText = name;
sidebarPath.append(iconWrapper, label);
sidebarPath.onclick = () => path.sidebar(name, page);
sidebarPaths.append(sidebarPath);
return sidebarPath;
}
createSidebarPath("Search", "search", searchPage);
createSidebarPath("Gamemodes", "gamepad", gamemodesPage);
createSidebarPath("Favorites", "star", favoritesPage);
// Hidden leaderboard entry stays exactly as you had it
(leaderboardPath = createSidebarPath("Leaderboard", "trophy", leaderboardPage)).style.display = "none";
createSidebarPath("Logs", "terminal", logsPage);
createSidebarPath("Alt Manager", "alt", altPage);
createSidebarPath("Blook Editor", "editor", blookPage);
createSidebarPath("Client Blooks", "client", clientPage);
createSidebarPath("Custom Modules", "module", modulePage);
createSidebarPath("Changelog", "changelog", changelogPage);
createSidebarPath("Settings", "cog", settingsPage);
createSidebarPath("Info/Credits", "info", creditsPage);
sidebar.append(sidebarPaths);
const bigTextContainer = document.createElement("div");
bigTextContainer.className = classes.bigTextContainer;
const dummyK = document.createElement("span");
dummyK.innerText = "X";
dummyK.style.opacity = "0";
const bigText = document.createElement("span");
bigText.className = classes.bigText;
bigText.innerText = "-GUI";
const logo = document.createElement("span");
logo.className = classes.logo;
logo.innerHTML = "X";
bigTextContainer.append(logo, dummyK, bigText);
sidebar.prepend(bigTextContainer);
const refreshControl = document.createElement("div");
refreshControl.className = classes.refreshControl;
refreshControl.innerHTML = `
<svg viewBox="0 0 24 24" width="22" height="22" fill="currentColor"
xmlns="http://www.w3.org/2000/svg" style="display:block;">
<path d="M4,12a1,1,0,0,1-2,0A9.983,9.983,0,0,1,18.242,4.206V2.758a1,1,0,1,1,2,0v4a1,1,0,0,1-1,1h-4a1,1,0,0,1,0-2h1.743A7.986,7.986,0,0,0,4,12Zm17-1a1,1,0,0,0-1,1A7.986,7.986,0,0,1,7.015,18.242H8.757a1,1,0,1,0,0-2h-4a1,1,0,0,0-1,1v4a1,1,0,0,0,2,0V19.794A9.984,9.984,0,0,0,22,12,1,1,0,0,0,21,11Z"/>
</svg>
`;
refreshControl.onclick = () => {
refreshControl.animate(
[{
transform: "rotate(0deg)"
}, {
transform: "rotate(360deg)"
}], {
duration: 600,
easing: "ease"
}
);
path.updatePath();
};
gui.append(controls, guiTopBar, sidebar, guiContent, pathText, refreshControl);
path.updatePath();
document.body.appendChild(gui);
// CSP Detection Function
function detectCSP() {
let cspDetected = false;
// Method 1: Try to execute inline script
try {
const testScript = document.createElement('script');
testScript.textContent = 'window.__cspTestPassed = true;';
document.head.appendChild(testScript);
document.head.removeChild(testScript);
if (!window.__cspTestPassed) {
cspDetected = true;
}
delete window.__cspTestPassed;
} catch (e) {
cspDetected = true;
}
// Method 2: Check for CSP meta tags
const cspMeta = document.querySelector('meta[http-equiv="Content-Security-Policy"]');
if (cspMeta && cspMeta.content.includes('script-src')) {
cspDetected = true;
}
return cspDetected;
}
// Function to create CSP overlay (similar to blur notice)
function createCSPOverlay(targetPage) {
// Check if overlay already exists
if (targetPage.querySelector && targetPage.querySelector('.xgui-csp-notice')) return;
// Apply blur to background content
try {
if (targetPage && targetPage.style) {
let blurTarget = targetPage.querySelector && targetPage.querySelector('.xgui-blur-target');
if (!blurTarget) {
blurTarget = document.createElement('div');
blurTarget.className = 'xgui-blur-target';
while (targetPage.firstChild) {
blurTarget.appendChild(targetPage.firstChild);
}
targetPage.appendChild(blurTarget);
}
blurTarget.style.filter = 'blur(8px)';
blurTarget.style.pointerEvents = 'none';
}
} catch (e) {}
// Create notice overlay
const notice = document.createElement("div");
notice.className = 'xgui-csp-notice';
try {
if (!targetPage.style.position || targetPage.style.position === 'static') targetPage.style.position = 'relative';
// Allow content to extend beyond the targetPage bounds
targetPage.style.overflow = 'visible';
} catch (e) {}
notice.style.cssText = `
position: absolute;
inset: 0;
display: flex !important;
align-items: flex-start !important;
justify-content: center !important;
z-index: 2000;
pointer-events: auto;
text-align: center;
background: transparent;
padding: 20px;
overflow: visible !important;
`;
const content = document.createElement('div');
content.className = 'xgui-csp-notice-content';
content.style.cssText = `
box-sizing: border-box !important;
display: block !important;
max-width: 380px !important;
width: 100% !important;
padding: 40px 35px !important;
border-radius: 20px !important;
backdrop-filter: blur(24px) saturate(180%) !important;
-webkit-backdrop-filter: blur(24px) saturate(180%) !important;
background: linear-gradient(145deg, rgba(138, 43, 226, 0.15), rgba(75, 0, 130, 0.1)) !important;
border: 1.5px solid rgba(255, 255, 255, 0.15) !important;
box-shadow:
0 10px 40px rgba(0, 0, 0, 0.5),
0 0 0 1px rgba(255, 255, 255, 0.08) inset,
0 25px 70px rgba(138, 43, 226, 0.2) !important;
text-align: center !important;
margin-top: -40px !important;
`;
const iconWrapper = document.createElement("div");
iconWrapper.innerHTML = `
<svg width="64" height="64" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M12 2L4 6V11C4 16 7 20 12 22C17 20 20 16 20 11V6L12 2Z" stroke="currentColor" stroke-width="2" stroke-linejoin="round"/>
<path d="M9 9L15 15M15 9L9 15" stroke="currentColor" stroke-width="2" stroke-linecap="round"/>
</svg>
`;
iconWrapper.style.cssText = `
display: block !important;
color: #FFFFFF !important;
margin: 0 auto 20px auto !important;
padding: 0 !important;
line-height: 1 !important;
filter: drop-shadow(0 4px 16px rgba(255, 255, 255, 0.3)) !important;
`;
const noticeTitle = document.createElement("div");
noticeTitle.textContent = "CSP Detected";
noticeTitle.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 32px !important;
font-weight: 800 !important;
line-height: 1.1 !important;
margin: 0 0 16px 0 !important;
padding: 0 !important;
text-align: center !important;
letter-spacing: -0.5px !important;
text-shadow: 0 2px 20px rgba(138, 43, 226, 0.6) !important;
`;
const noticeText = document.createElement("div");
noticeText.innerHTML = "This is not supported on your version. Please use the extension version or get the CSP unblock extension.";
noticeText.style.cssText = `
display: block !important;
color: #FFFFFF !important;
font-size: 15px !important;
margin: 0 0 30px 0 !important;
padding: 0 !important;
text-align: center !important;
line-height: 1.6 !important;
font-weight: 400 !important;
`;
const buttonContainer = document.createElement("div");
buttonContainer.style.cssText = `
display: flex !important;
flex-direction: column !important;
gap: 12px !important;
`;
const extensionButton = document.createElement("a");
extensionButton.href = "https://github.com/xgui-client/X-GUI-BLOOKET-CLIENT/raw/refs/heads/main/extension/x-gui-extension.zip";
extensionButton.target = "_blank";
extensionButton.textContent = "Get Extension";
extensionButton.style.cssText = `
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
background: linear-gradient(135deg, #5865F2, #4752C4) !important;
color: #FFFFFF !important;
border: none !important;
font-size: 15px !important;
font-weight: 600 !important;
cursor: pointer !important;
padding: 14px 32px !important;
border-radius: 12px !important;
transition: all 0.3s ease !important;
box-shadow: 0 6px 20px rgba(88, 101, 242, 0.4) !important;
margin: 0 !important;
letter-spacing: 0.3px !important;
text-decoration: none !important;
`;
extensionButton.addEventListener('mouseenter', function() {
this.style.transform = 'translateY(-3px) scale(1.02)';
this.style.boxShadow = '0 10px 30px rgba(88, 101, 242, 0.6)';
});
extensionButton.addEventListener('mouseleave', function() {
this.style.transform = 'translateY(0) scale(1)';
this.style.boxShadow = '0 6px 20px rgba(88, 101, 242, 0.4)';
});
buttonContainer.appendChild(extensionButton);
content.appendChild(iconWrapper);
content.appendChild(noticeTitle);
content.appendChild(noticeText);
content.appendChild(buttonContainer);
notice.append(content);
try { targetPage.append(notice); } catch (e) { document.body.append(notice); }
}
// Add the CSP overlay if it detects CSP and Logs it
if (detectCSP()) {
Logs.addLog("CSP Detected - Custom modules disabled", "red");
createCSPOverlay(modulePage);
}
Logs.addLog("Opened X-GUI!");
/* Anti-Suspend By CryptoDude3 */
if (window.fetch.call.toString() == "function call() { [native code] }") {
const call = window.fetch.call;
window.fetch.call = function() {
if (!arguments[1].includes("s.blooket.com/rc")) return call.apply(this, arguments);
Logs.addLog("Blocked Suspension API!", "red");
};
Logs.addLog("Enabled Anti-BAN!");
}
if (gui.querySelector("i").clientHeight == 0) {
const link = document.createElement("link");
link.rel = "stylesheet";
link.href = "https://ka-f.fontawesome.com/releases/v6.5.1/css/pro.min.css";
gui.prepend(link);
}
function randString(length) {
return Array.from({
length
}, () => String.fromCharCode(Math.floor(Math.random() * 25) + 97)).reduce((a) => a + String.fromCharCode(Math.floor(Math.random() * 25) + 97), "");
}
function dragElement(element, parent) {
var pos1 = 0,
pos2 = 0,
pos3 = 0,
pos4 = 0;
element.onpointerdown = function(e = window.event) {
element.style.cursor = "grabbing";
pos3 = e.clientX;
pos4 = e.clientY;
document.onpointerup = function() {
element.style.cursor = "grab";
document.onpointerup = null;
document.onpointermove = null;
};
document.onpointermove = function(e = window.event) {
pos1 = pos3 - e.clientX;
pos2 = pos4 - e.clientY;
pos3 = e.clientX;
pos4 = e.clientY;
parent.style.top = parent.offsetTop - pos2 + "px";
parent.style.left = parent.offsetLeft - pos1 + "px";
};
};
}
const keys = ["shift", "control", "alt", "meta"];
function createKeybindListener(onpress, element = window) {
return new Promise((resolve) => {
const pressed = new Set();
let shift, ctrl, alt, key;
const keydown = (e) => {
e.preventDefault();
pressed.add(e.code);
shift ||= e.shiftKey;
ctrl ||= e.ctrlKey;
alt ||= e.altKey;
if (!keys.includes(e.key.toLowerCase())) key = e.key.toLowerCase();
onpress?.({
shift,
ctrl,
alt,
key
});
};
const keyup = (e) => {
pressed.delete(e.code);
if (pressed.size > 0) return;
element.removeEventListener("keydown", keydown);
element.removeEventListener("keyup", keyup);
resolve({
shift,
ctrl,
alt,
key
});
};
element.addEventListener("keydown", keydown);
element.addEventListener("keyup", keyup);
});
}
function parseKeybind({
shift,
ctrl,
alt,
key
}) {
return [ctrl && "Ctrl", shift && "Shift", alt && "Alt", key && key.toUpperCase()].filter(Boolean).join(" + ");
}
function compareKeybind(keybind, event) {
return keybind.ctrl == event.ctrlKey && keybind.shift == event.shiftKey && keybind.alt == event.altKey && event.key.toLowerCase() == keybind.key;
}
function keydown(e) {
if (compareKeybind(Settings.data.hideKey ?? defaultHideKey, e)) {
e.preventDefault();
const isHiding = gui.style.display === "block";
if (window.xguiAnimationsEnabled) {
const animationDuration = 0.1;
if (isHiding) {
gui.style.animation = `guiFadeOut ${animationDuration}s ease-out`;
setTimeout(() => {
gui.style.display = "none";
gui.style.animation = "";
}, animationDuration * 1000);
} else {
gui.style.display = "block";
gui.style.animation = `guiFadeIn ${animationDuration}s ease-out`;
setTimeout(() => {
gui.style.animation = "";
}, animationDuration * 0.1);
}
} else {
gui.style.animation = "none";
gui.style.display = isHiding ? "none" : "block";
}
return;
}
if (compareKeybind(Settings.data.closeKey ?? defaultCloseKey, e)) {
e.preventDefault();
close();
}
}
function close() {
const animationsEnabled = getCookieValue("animationsEnabled");
if (animationsEnabled) {
const animationDuration = 0.3;
gui.style.animation = `guiFadeOut ${animationDuration}s ease-out forwards`;
gui.style.pointerEvents = 'none';
setTimeout(() => {
gui.remove();
clearInterval(Logs.interval);
for (const category in cheats)
for (const cheat of cheats[category].cheats)
if (cheat.enabled) cheat.run();
window.removeEventListener("keydown", keydown);
}, animationDuration * 1000);
} else {
gui.remove();
clearInterval(Logs.interval);
for (const category in cheats)
for (const cheat of cheats[category].cheats)
if (cheat.enabled) cheat.run();
window.removeEventListener("keydown", keydown);
}
}
function getStateNode() {
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;
}
window.addEventListener("keydown", keydown);
});
let img = new Image;
img.src = "https://cdn.jsdelivr.net/gh/Blooket-Council/Blooket-Cheats@main/autoupdate/timestamps/KGui.png?" + Date.now();
img.crossOrigin = "Anonymous";
img.onload = function() {
const c = document.createElement("canvas");
const ctx = c.getContext("2d");
ctx.drawImage(img, 0, 0, this.width, this.height);
let {
data
} = ctx.getImageData(0, 0, this.width, this.height), decode = "", last;
let i = 0;
while (i < data.length) {
let char = String.fromCharCode(data[i % 4 == 3 ? (i++, i++) : i++] + data[i % 4 == 3 ? (i++, i++) : i++] * 256);
decode += char;
if (char == "/" && last == "*") break;
last = char;
}
let _, time = timeProcessed,
error = "There was an error checking for script updates. Run cheat anyway?";
try {
[_, time, error] = decode.match(/LastUpdated: (.+?); ErrorMessage: "((.|\n)+?)"/);
} catch (e) {}
if ((latestProcess = parseInt(time)) <= timeProcessed || iframe.contentWindow.confirm(error)) cheat();
}
img.onerror = img.onabort = () => {
img.onerror = img.onabort = null;
cheat();
let iframe = document.querySelector("iframe");
}
})();