IdlePixel Slap Chop - GodofNades Fork

Ain't nobody got time for that! Adds some QoL 1-click actions.

// ==UserScript==
// @name         IdlePixel Slap Chop - GodofNades Fork
// @namespace    com.anwinity.idlepixel
// @version      3.0.15
// @description  Ain't nobody got time for that! Adds some QoL 1-click actions.
// @author       Original Author: Anwinity || Modded By: GodofNades
// @license      MIT
// @match        *://idle-pixel.com/login/play*
// @grant        none
// @require      https://greasyfork.org/scripts/441206-idlepixel/code/IdlePixel+.js?anticache=20220905
// ==/UserScript==

(function () {
    "use strict";

    // Overall Declarations for different variables used throughout the script
    let IPP, getVar, getThis, singleOverride;
    let foundryToggle = true;
    let smelteryToggle = true;
    const IMAGE_URL_BASE = document
    .querySelector("itembox[data-item=copper] img")
    .src.replace(/\/[^/]+.png$/, "");
    let loaded = false;
    let onLoginLoaded = false;

    // Start New Code Base Const/Functions
    const misc = function () {
        return {
            initStyles: function () {
                var style = document.createElement("style");
                style.id = "styles-slapchop";
                style.innerHTML = `
                    #slapchop-quickfight, #slapchop-quickpreset {
                        position: relative;
                    }

                    #slapchop-quickpreset > .slapchop-quickpreset-buttons {
                        display: flex;
                        flex-direction: row;
                        justify-content: start;
                    }

                    #slapchop-quickpreset > .slapchop-quickpreset-buttons > div {
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                    }

                    #slapchop-quickpreset > .slapchop-quickpreset-buttons > div > button {
                        margin: 0.125em;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons {
                        display: flex;
                        flex-direction: row;
                        flex-wrap: wrap;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone {
                        width: 150px;
                        max-width: 150px;
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                        align-items: center;
                        position: relative;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone.blood button {
                        font-weight: 550;
                        background-color: rgb(136, 8, 8) !important;
                        color: rgb(255,255,255);
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone.blood button:disabled {
                        color: rgba(255,255,255,0.3);
                        background-color: rgba(136, 8, 8, 0.3) !important;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > * {
                        width: 100%;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container {
                        width: 100%;
                        color: white;
                        text-shadow: 1px 0 0 #000, 0 -1px 0 #000, 0 1px 0 #000, -1px 0 0 #000;
                        text-align: left;
                        position: relative;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container > .slapchop-quickfight-progress-value {
                        position: relative;
                        z-index: 5;
                        margin-left: 4px;
                        font-weight: bold;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container.slapchop-quickfight-fightpoints {
                        background-color: rgba(255, 216, 0, 0.5);
                        border: 1px solid rgb(255, 216, 0);
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container.slapchop-quickfight-fightpoints .slapchop-quickfight-progress {
                        background-color: #ffd800;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container.slapchop-quickfight-energy {
                        background-color: rgba(215, 0, 71, 0.5);
                        border: 1px solid rgb(215, 0, 71);
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container.slapchop-quickfight-energy .slapchop-quickfight-progress {
                        background-color: #d70047;
                    }

                    #slapchop-quickfight > .slapchop-quickfight-buttons .slapchop-quickfight-zone > .slapchop-quickfight-progress-container > .slapchop-quickfight-progress {
                        position: absolute;
                        top: 0;
                        left: 0;
                        height: 100%;
                        width: 0; /* will be overwritten inline */
                        z-index: 3;
                    }

                    #slapchop-quicklamp > .slapchop-quickfight-buttons .slapchop-quickfight-zone {
                        width: 150px;
                        max-width: 150px;
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                        align-items: center;
                        position: relative;
                    }

                    #brewing-table .slapchop-quickbrew-button {
                        border: 1px solid rgba(124, 218, 255, 0.86);
                        background-color: rgba(124, 218, 255, 0.1);
                        padding: 2px;
                        display: flex;
                        justify-content: center;
                        align-items: center;
                        margin: 0.5em auto 0.125em auto;
                        max-width: 100px;
                    }

                    #brewing-table .slapchop-quickbrew-button:hover {
                        background-color: rgba(69, 177, 216, 0.5);
                    }

                    #crafting-table .slapchop-rocketfuelmax-button {
                        border: 1px solid rgba(124, 218, 255, 0.86);
                        background-color: rgba(124, 218, 255, 0.1);
                        padding: 2px;
                        display: flex;
                        justify-content: center;
                        align-items: center;
                        margin: 0.5em auto 0.125em auto;
                        max-width: 150px;
                    }

                    #crafting-table .slapchop-rocketfuelmax-button:hover {
                        background-color: rgba(69, 177, 216, 0.5);
                    }

                    #crafting-table .slapchop-rocketfuelsingle-button {
                        border: 1px solid rgba(124, 218, 255, 0.86);
                        background-color: rgba(124, 218, 255, 0.1);
                        padding: 2px;
                        display: flex;
                        justify-content: center;
                        align-items: center;
                        margin: 0.5em auto 0.125em auto;
                        max-width: 150px;
                    }

                    #crafting-table .slapchop-rocketfuelsingle-button:hover {
                        background-color: rgba(69, 177, 216, 0.5);
                    }

                    #quick-lamp-zone {
                        display: flex;
                        flex-direction: row;
                        flex-wrap: wrap;
                    }

                    #lamp-zone-all {
                        display: inline-flex;
                    }

                    #melee-lamp-zone {
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                        align-items: center;
                        position: relative;
                    }

                    #archery-lamp-zone {
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                        align-items: center;
                        position: relative;
                        padding-left: 20px;
                    }

                    #magic-lamp-zone {
                        display: flex;
                        flex-direction: column;
                        justify-content: start;
                        align-items: center;
                        position: relative;
                        padding-left: 20px;
                    }

                    .fighting-monster-loot-potion {
                        background-color: rgba(32, 36, 33, 0.67);
                        border-color: rgb(255, 255, 255) rgb(255, 255, 255) rgb(255, 255, 255) rgb(255, 255, 255);
                        color: rgb(232, 230, 227);
                        border: 1px solid black;
                        border-top-color: black;
                        border-top-style: solid;
                        border-top-width: 1px;
                        border-right-color: black;
                        border-bottom-color: black;
                        border-bottom-style: solid;
                        border-bottom-width: 1px;
                        border-left-color: black;
                        border-left-style: solid;
                        border-left-width: 1px;
                        padding: 10px;
                        color: white;
                        border-bottom-right-radius: 5px;
                        border-top-right-radius: 5px;
                        margin-right: -3px;
                        margin-top: 20px;
                    }

                    .fighting-monster-rain-potion {
                        background-color: rgba(38, 115, 153, 0.67);
                        border-color: rgb(33, 207, 247);
                        color: rgb(232, 230, 227);
                        border: 1px solid black;
                        border-top-color: black;
                        border-top-style: solid;
                        border-top-width: 1px;
                        border-right-color: black;
                        border-bottom-color: black;
                        border-bottom-style: solid;
                        border-bottom-width: 1px;
                        border-left-color: black;
                        border-left-style: solid;
                        border-left-width: 1px;
                        padding: 10px;
                        color: white;
                        border-bottom-right-radius: 5px;
                        border-top-right-radius: 5px;
                        margin-right: -3px;
                        margin-top: 20px;
                    }

                    .lumberjack-rain-pot-woodcutting {
                        width:100px;
                        height:100px;
                        display: inline-block;
                        border:1px solid rgb(66, 66, 66);
                        background: rgb(8,115,0);
                        background: linear-gradient(0deg, rgba(8,115,0,1) 6%, rgba(55,45,253,1) 25%, rgba(55,45,253,1) 50%, rgba(101,101,101,1) 75%, rgba(52,52,52,1) 100%);
                        border-radius: 5pt;
                        color:white;
                    }

                    #rare_monster_potion-brew {
                        padding: 3px;
                        width: 50px;
                    }

                    #rare_monster_potion-use {
                        padding: 3px;
                        width: 50px;
                    }

                    #super_rare_monster_potion-brew {
                        padding: 3px;
                        width: 50px;
                    }

                    #super_rare_monster_potion-use {
                        padding: 3px;
                        width: 50px;
                    }

                    #combat_loot_potion-label {
                        color: white;
                    }

                    #rain_potion-in-combat-label {
                        color: white;
                    }

                    #rain_potion-brew {
                        padding: 3px;
                        width: 50px;
                    }

                    #rain_potion-use {
                        padding: 3px;
                        width: 50px;
                    }

                    .itembox-fight-center {
                        margin-top: 0.55rem;
                        text-align: center;
                    }

                    .center-flex {
                        display: flex;
                        justify-content: center;
                        text-align: center;
                    }
                `;
                document.head.appendChild(style);
            },

            updateButtons: function () {
                let potions = ["rare_monster_potion", "super_rare_monster_potion"];
                potions.forEach((potion) => {
                    let useButton = document.getElementById(`${potion}-use`);
                    let brewButton = document.getElementById(`${potion}-brew`);
                    getVar(potion, 0, "int")
                        ? (useButton.style.color = "white")
                    : (useButton.style.color = "red");
                    sCBrewing().canBrew(potion)
                        ? (brewButton.style.color = "white")
                    : (brewButton.style.color = "red");
                });
                let combatLootPotionsAmount = document.getElementById(
                    "combat_loot_potion-label"
                );
                combatLootPotionsAmount.textContent =
                    getVar("combat_loot_potion_timer", 0, "int") == 0
                    ? "Loot Potions: " + getVar("combat_loot_potion", 0, "int")
                : format_time(getVar("combat_loot_potion_timer", 0, "int"));
                let rainPotionsAmount = document.getElementById(
                    "rain_potion-in-combat-label"
                );
                rainPotionsAmount.textContent =
                    getVar("rain_potion_timer", 0, "int") == 0
                    ? "Rain Potions: " + getVar("rain_potion", 0, "int")
                : format_time(getVar("rain_potion_timer", 0, "int"));
            },
        };
    };

    const actionType = function () {
        return {
            primary: function (event) {
                const prop = getThis.getConfig("primaryActionKey") || "none";
                if (prop == "none") {
                    return !(event.altKey || event.ctrlKey || event.shiftKey);
                } else {
                    return event[prop];
                }
            },

            alt: function (event) {
                const prop = getThis.getConfig("altActionKey") || "altKey";
                return event[prop];
            },
        };
    };

    const mining_crafting = function () {
        window.SCMACHINES = [
            "drill",
            "crusher",
            "giant_drill",
            "excavator",
            "giant_excavator",
            "massive_excavator",
        ];

        window.SCMINERAL = [
            "amber_mineral",
            "amethyst_mineral",
            "blood_crystal_mineral",
            "blue_marble_mineral",
            "clear_marble_mineral",
            "dense_marble_mineral",
            "fluorite_mineral",
            "frozen_mineral",
            "jade_mineral",
            "lime_quartz_mineral",
            "magnesium_mineral",
            "opal_mineral",
            "purple_quartz_mineral",
            "sea_crystal_mineral",
            "smooth_pearl_mineral",
            "sulfer_mineral",
            "tanzanite_mineral",
            "topaz_mineral",
        ];

        window.SCMINING = [
            "small_stardust_prism",
            "medium_stardust_prism",
            "large_stardust_prism",
            "huge_stardust_prism",
            "grey_geode",
            "blue_geode",
            "green_geode",
            "red_geode",
            "cyan_geode",
            "ancient_geode",
            "meteor",
        ];

        window.SCSMELTABLES = [
            "copper",
            "iron",
            "silver",
            "gold",
            "promethium",
            "titanium",
            "ancient_ore",
            "dragon_ore",
        ];

        return {
            // Quick Smelting
            initQuickSmelt: function () {
                let htmlMining = `
                    <div id="slapchop-quicksmelt-mining" class="slapchop-quicksmelt">
                      <h5>Quick Smelt:</h5>
                      <div class="slapchop-quicksmelt-buttons">
                    `;
                SCSMELTABLES.forEach((ore) => {
                    htmlMining += `
                        <button type="button" onclick="sCMiningCrafting().quickSmelt('${ore}')">
                            <img src="${IMAGE_URL_BASE}/${ore}.png" class="img-20" />
                            ${ore
                        .replace(/_/g, " ")
                        .replace(/(^|\s)\w/g, (s) => s.toUpperCase())}
                            (<span data-slap="max-smelt-${ore}">?</span>)
                        </button>
                    `;
                });
                htmlMining += `
                        </div>
                        <hr>
                    </div>
                `;
                const panelMining = document.querySelector("#panel-mining .panel-logo-xp-area");
                panelMining.insertAdjacentHTML("afterend", htmlMining);

                let htmlCrafting = `
                    <div id="slapchop-quicksmelt-crafting" class="slapchop-quicksmelt">
                        <h5>Quick Smelt:</h5>
                        <div class="slapchop-quicksmelt-buttons">
                 `;
                SCSMELTABLES.forEach((ore) => {
                    htmlCrafting += `
                        <button type="button" onclick="sCMiningCrafting().quickSmelt('${ore}')">
                            <img src="${IMAGE_URL_BASE}/${ore}.png" class="img-20" />
                            ${ore
                        .replace(/_/g, " ")
                        .replace(/(^|\s)\w/g, (s) => s.toUpperCase())}
                           (<span data-slap="max-smelt-${ore}">?</span>)
                        </button>
                    `;
                });
                htmlCrafting += `
                        </div>
                        <hr>
                    </div>
                `;

                const panelCrafting = document.querySelector("#panel-crafting .panel-logo-xp-area");
                panelCrafting.insertAdjacentHTML("afterend", htmlCrafting);

                SCSMELTABLES.forEach((ore) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${ore}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickSmeltRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCMiningCrafting().quickSmelt(ore, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            maxSmeltable: function (ore) {
                const oilPerOre = Crafting.getOilPerBar(ore);
                const charcoalPerOre = Crafting.getCharcoalPerBar(ore);
                const lavaPerOre = Crafting.getLavaPerBar(ore);
                const plasmaPerOre = Crafting.getPlasmaPerBar(ore);

                const oil = getVar("oil", 0, "int");
                const capacity = Furnace.getFurnaceCapacity();
                const oreCount = getVar(ore, 0, "int");
                const maxSmeltFromOil = Math.floor(oil / oilPerOre);
                const dragonFire = getVar("dragon_fire", 0, "int");
                let maxSmeltCount = Math.min(capacity, oreCount, maxSmeltFromOil);

                if (charcoalPerOre > 0) {
                    const charcoal = getVar("charcoal", 0, "int");
                    const maxSmeltFromCharcoal = Math.floor(charcoal / charcoalPerOre);
                    maxSmeltCount = Math.min(maxSmeltCount, maxSmeltFromCharcoal);
                }
                if (lavaPerOre > 0) {
                    const lava = getVar("lava", 0, "int");
                    const maxSmeltFromLava = Math.floor(lava / lavaPerOre);
                    maxSmeltCount = Math.min(maxSmeltCount, maxSmeltFromLava);
                }
                if (plasmaPerOre > 0) {
                    const plasma = getVar("plasma", 0, "int");
                    const maxSmeltFromPlasma = Math.floor(plasma / plasmaPerOre);
                    maxSmeltCount = Math.min(maxSmeltCount, maxSmeltFromPlasma);
                }
                if (ore == "dragon_ore") {
                    maxSmeltCount = Math.min(maxSmeltCount, dragonFire);
                }
                if (ore == "copper") {
                    maxSmeltCount = Math.min(capacity, oreCount);
                }
                return maxSmeltCount || 0;
            },

            quickSmelt: function (ore) {
                if (smelteryToggle) {
                    smelteryToggle = false;
                    const current = getVar("furnace_ore_type", "none");
                    if (current == "none") {
                        const max = sCMiningCrafting().maxSmeltable(ore);
                        if (max > 0) {
                            IdlePixelPlus.sendMessage(`SMELT=${ore}~${max}`);
                        }
                    }
                    setTimeout(function () {
                        smelteryToggle = true;
                    }, 1000);
                }
            },

            maxCraftable: function () {
                const oilPerFuel = 5000;
                const charcoalPerFuel = 20;
                const lavaPerFuel = 1;
                const oil = getVar("oil", 0, "int");
                const maxFuelFromOil = Math.floor(oil / oilPerFuel);
                let maxFuelCount = Math.min(maxFuelFromOil);
                if (charcoalPerFuel > 0) {
                    const charcoal = getVar("charcoal", 0, "int");
                    const maxCraftFromCharcoal = Math.floor(charcoal / charcoalPerFuel);
                    maxFuelCount = Math.min(maxFuelCount, maxCraftFromCharcoal);
                }
                if (lavaPerFuel > 0) {
                    const lava = getVar("lava", 0, "int");
                    const maxCraftFromLava = Math.floor(lava / lavaPerFuel);
                    maxFuelCount = Math.min(maxFuelCount, maxCraftFromLava);
                }
                return maxFuelCount || 0;
            },

            updateMaxCraftable: function () {
                const max = sCMiningCrafting().maxCraftable();
                const maxText = "Quick Craft Max (" + max + ")";
                const oilMax = 5000 * max;
                const oilText = "5,000 (" + oilMax.toLocaleString() + ") (oil)";
                const coalMax = 20 * max;
                const coalText = "20 (" + coalMax.toLocaleString() + ") (charcoal)";
                const lavaMax = 1 * max;
                const lavaText = "1 (" + lavaMax.toLocaleString() + ") (lava)";
                const label = document.querySelector(
                    "#crafting-table tbody tr[data-crafting-item=rocket_fuel] td item-crafting-table[data-materials-item]"
                ).dataset.materialsItem;

                const maxCraftableButton = document.querySelector(
                    "#crafting-table .slapchop-rocketfuelmax-button"
                );
                const oilTableCell = document.querySelector(
                    "#crafting-table tbody tr[data-crafting-item=rocket_fuel] td item-crafting-table[data-materials-item=oil]"
                );
                const coalTableCell = document.querySelector(
                    "#crafting-table tbody tr[data-crafting-item=rocket_fuel] td item-crafting-table[data-materials-item=charcoal]"
                );
                const lavaTableCell = document.querySelector(
                    "#crafting-table tbody tr[data-crafting-item=rocket_fuel] td item-crafting-table[data-materials-item=lava"
                );
                const singleCraftButton = document.querySelector(
                    "#crafting-table .slapchop-rocketfuelsingle-button"
                );

                if (maxCraftableButton) {
                    maxCraftableButton.textContent = maxText;
                }

                if (oilTableCell) {
                    oilTableCell.textContent = oilText;
                }

                if (coalTableCell) {
                    coalTableCell.textContent = coalText;
                }

                if (lavaTableCell) {
                    lavaTableCell.textContent = lavaText;
                }

                if (singleCraftButton) {
                    if (max === 0) {
                        singleCraftButton.style.display = "none";
                    } else {
                        singleCraftButton.style.display = "block";
                    }
                }
            },

            updateQuickSmelt: function () {
                SCSMELTABLES.forEach((ore) => {
                    const max = sCMiningCrafting().maxSmeltable(ore);
                    const elements = document.querySelectorAll(
                        `[data-slap="max-smelt-${ore}"]`
					);
                    elements.forEach((element) => {
                        element.textContent = max;
                    });
                });
            },

            // Quick Mining
            initQuickMining: function () {
                SCMINING.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickMiningRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCMiningCrafting().quickMining(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            quickMining: function (item, alt) {
                let n = getVar(item, 0, "int");
                if (alt || singleOverride) {
                    console.log("Inside the minus: " + singleOverride);
                    n--;
                }
                if (n > 0) {
                    if (item.includes("_stardust_prism")) {
                        IdlePixelPlus.sendMessage(`SMASH_STARDUST_PRISM=${item}~${n}`);
                    } else if (item.includes("_geode")) {
                        IdlePixelPlus.sendMessage(`CRACK_GEODE=${item}~${n}`);
                    } else if (item == "meteor") {
                        websocket.send(`MINE_METEOR`);
                    }
                }
            },

            // Quick Mineral
            initQuickMineral: function () {
                SCMINERAL.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickMineralRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCMiningCrafting().quickMineral(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            quickMineral: function (item, alt) {
                let n = getVar(item, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`MINERAL_XP=${item}~${n}`);
                }
            },

            // Mining Machine Presets
            initMiningPresets: function () {
                let html = `
                    <div id="miningmachines-presets">
                        <h5>Mining Machine Presets:</h5>
                        <div id="slapchop-quickpreset">
                            <div class="slapchop-quickpreset-buttons">
                                <div>
                                    <button onclick="sCMiningCrafting().noMachines()">None</button>
                                </div>
                                <div>
                                    <button onclick="sCMiningCrafting().miningPresetSave(2)">Save 2</button>
                                    <button onclick="sCMiningCrafting().miningPresetLoad(2)">Load 2</button>
                                </div>
                                <div>
                                    <button onclick="sCMiningCrafting().miningPresetSave(3)">Save 3</button>
                                    <button onclick="sCMiningCrafting().miningPresetLoad(3)">Load 3</button>
                                </div>
                                <div>
                                    <button onclick="sCMiningCrafting().miningPresetSave(4)">Save 4</button>
                                    <button onclick="sCMiningCrafting().miningPresetLoad(4)">Load 4</button>
                                </div>
                                <div>
                                    <button onclick="sCMiningCrafting().allMachines()">All</button>
                                </div>
                            </div>
                        </div>
                        <hr>
                    </div>
                `;
                document
                    .querySelector("div.fresh-account-buy-pickaxe-text")
                    .insertAdjacentHTML("beforebegin", html);
            },

            miningPresetSave: function (presetNumber) {
                let presetData = {};
                let presetName = `Preset ${presetNumber}`;
                let username = getVar("username", "", "string");

                SCMACHINES.forEach(function (machine) {
                    let machineCount = `${machine}_on`;
                    let ippMachineOnCount = getVar(machineCount, 0, "int");
                    presetData[machine] = ippMachineOnCount;
                });

                let allPresets =
                    JSON.parse(localStorage.getItem(`${username}.miningPresets`)) || {};

                allPresets[presetName] = presetData;

                localStorage.setItem(
                    `${username}.miningPresets`,
                    JSON.stringify(allPresets)
                );
            },

            miningPresetLoad: function (presetNumber) {
                SCMACHINES.forEach(function (machine) {
                    let machineCount = `${machine}_on`;
                    let ippMachineOnCount = getVar(machineCount, 0, "int");
                    let ippMachineCrafted = getVar(machine, 0, "int");
                    let i = ippMachineOnCount;
                    while (i > 0) {
                        i--;
                        websocket.send(`MACHINERY=${machine}~decrease`);
                    }
                });

                let username = getVar("username", "", "string");
                let allPresets =
                    JSON.parse(localStorage.getItem(`${username}.miningPresets`)) || {};
                let presetName = `Preset ${presetNumber}`;
                let presetData = allPresets[presetName];

                if (!presetData) {
                    return;
                }

                SCMACHINES.forEach(function (machine) {
                    let machineCount = `${machine}_on`;
                    let ippMachineOnCount = getVar(machineCount, 0, "int");
                    let ippMachinePresetCount = presetData[machine] || 0;

                    let i = 0;

                    while (i < ippMachinePresetCount) {
                        i++;
                        websocket.send(`MACHINERY=${machine}~increase`);
                    }
                });
            },

            allMachines: function () {
                SCMACHINES.forEach(function (machine) {
                    let machineCount = `${machine}_on`;
                    let ippMachineOnCount = getVar(machineCount, 0, "int");
                    let ippMachineCrafted = getVar(machine, 0, "int");
                    let i = ippMachineOnCount;
                    while (i < ippMachineCrafted) {
                        i++;
                        websocket.send(`MACHINERY=${machine}~increase`);
                    }
                });
            },

            noMachines: function () {
                SCMACHINES.forEach(function (machine) {
                    let machineCount = `${machine}_on`;
                    let ippMachineOnCount = getVar(machineCount, 0, "int");
                    let ippMachineCrafted = getVar(machine, 0, "int");
                    let i = ippMachineOnCount;
                    while (i > 0) {
                        i--;
                        websocket.send(`MACHINERY=${machine}~decrease`);
                    }
                });
            },

            // Rocket Fuel Crafting
            initQuickRocketFuel: function () {
                const rows = document.querySelectorAll(
                    "#crafting-table tbody tr[data-crafting-item=rocket_fuel]"
                );
                rows.forEach((row) => {
                    const craft = row.getAttribute("data-crafting-item");
                    if (!craft) {
                        return;
                    }

                    const fourthTd = row.querySelector("td:nth-child(4)");
                    if (fourthTd) {
                        fourthTd.insertAdjacentHTML(
                            "beforeend",
                            `
                            <div class="slapchop-rocketfuelsingle-button"
                                onclick="event.stopPropagation(); sCMiningCrafting().quickCraftSingle()">Quick Craft 1</div>
                            <div class="slapchop-rocketfuelmax-button"
                                onclick="event.stopPropagation(); sCMiningCrafting().quickCraft()">Quick Craft Max</div>
                        `
						);
                    }
                });
            },

            quickCraft: function () {
                const max = sCMiningCrafting().maxCraftable();
                if (max > 0) {
                    IdlePixelPlus.sendMessage(`CRAFT=rocket_fuel~${max}`);
                }
            },

            quickCraftSingle: function () {
                IdlePixelPlus.sendMessage(`CRAFT=rocket_fuel~1`);
            },
        };
    };

    const gathering = function () {
        window.SCLOOT_BAGS = Array.from(
            document.querySelectorAll(`itembox[data-item^="gathering_loot_bag_"]`)
        ).map((el) => el.getAttribute("data-item"));

        return {
            quickGather: function (bag, alt) {
                let n = getVar(bag, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(
                        `OPEN_GATHERING_LOOT=${bag.replace("gathering_loot_bag_", "")}~${n}`
					);
                }
            },

            initQuickGather: function () {
                SCLOOT_BAGS.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickGatherRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCGathering().quickGather(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },
        };
    };

    const farming = function () {
        window.SCBONEMEALABLE = [
            "bones",
            "big_bones",
            "ice_bones",
            "ashes",
            "blood_bones",
        ];

        window.SCPLANTABLES = Array.from(
            document.querySelectorAll('itembox[data-item$="_seeds"]')
        ).map((el) => el.getAttribute("data-item"));

        return {
            quickBone: function (item, alt) {
                if (getVar("bonemeal_bin", 0, "int") != 0) {
                    let n = getVar(item, 0, "int");
                    singleOverride = getThis.getConfig("autoSingleEnabled");
                    if (alt || singleOverride) {
                        n--;
                    }
                    if (n > 0) {
                        IdlePixelPlus.sendMessage(`ADD_BONEMEAL=${item}~${n}`);
                    }
                }
            },

            initQuickBones: function () {
                SCBONEMEALABLE.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickBoneRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCFarming().quickBone(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            initQuickHarvest: function () {
                const firstItemBox = document.querySelector("#panel-farming itembox");
                if (firstItemBox) {
                    firstItemBox.insertAdjacentHTML(
                        "beforebegin",
                        `
                        <itembox id="slapchop-bob" class="shadow hover" data-item="slapchop_bob" onclick="sCFarming().quickHarvest()">
                            <div class="center mt-1"><img width="50" height="50" src=""></div>
                            <div class="center mt-2">Harvest</div>
                        </itembox>
                    `
					);
                }

                const notificationFarmingReady = document.querySelector(
                    "#notification-farming-ready"
                );
                if (notificationFarmingReady) {
                    if (getThis.getConfig("quickHarvestNotificationEnabled")) {
                        notificationFarmingReady.setAttribute(
                            "onclick",
                            `sCFarming().quickHarvest(); switch_panels('panel-farming')`
						);
                    } else {
                        notificationFarmingReady.setAttribute(
                            "onclick",
                            `switch_panels('panel-farming')`
						);
                    }
                }
            },

            quickHarvest: function () {
                for (let i = 1; i <= 5; i++) {
                    let status = getVar("farm_stage_" + i, 0, "int");
                    if (status == 4) {
                        IdlePixelPlus.sendMessage("CLICKS_PLOT=" + i);
                    }
                }
            },

            quickPlant: function (seed, alt) {
                let n = getVar(seed, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (!alt && !singleOverride && n > 1) {
                    n = 1;
                }
                const donor = DonorShop.has_donor_active(
                    Items.getItem("donor_farm_patches_timestamp")
                );
                const maxPlot = donor ? 5 : 3;
                for (let plot = 1; plot <= maxPlot && n > 0; plot++) {
                    if (getVar(`farm_${plot}`) == "none") {
                        IdlePixelPlus.sendMessage(`PLANT=${seed}~${plot}`);
                        n--;
                    }
                }
            },

            initQuickPlant: function () {
                SCPLANTABLES.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickPlantRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    if (getThis.getConfig("quickPlantHarvestRightClickEnabled")) {
                                        sCFarming().quickHarvest();
                                    }
                                    sCFarming().quickPlant(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },
        };
    };

    const brewing = function () {
        window.POTIONS = Object.keys(Brewing.POTION_TIMERS);

        window.POTIONSNOTIMER = [
            "cooks_dust_potion",
            "fighting_dust_potion",
            "tree_dust_potion",
            "farm_dust_potion",
        ];

        POTIONSNOTIMER.forEach((potion) => {
            POTIONS.push(potion);
        });

        return {
            canBrew: function (potion) {
                let ingredients = Brewing.get_ingredients(potion);
                for (let i = 0; i < ingredients.length; i += 2) {
                    if (getVar(ingredients[i], 0, "int") < ingredients[i + 1])
                        return false;
                }
                return true;
            },

            quickPotion: function (potion, alt) {
                let n = getVar(potion, 0, "int");
                //console.log(potion);
                if (alt || singleOverride) {
                    n--;
                }
                if (!alt && !singleOverride && n > 1) {
                    n = 1;
                }
                if (n > 0) {
                    if (
                        potion == "combat_loot_potion" &&
                        var_combat_loot_potion_timer == 0
                    ) {
                        websocket.send(`BREWING_DRINK_COMBAT_LOOT_POTION`);
                    } else if (
                        potion == "rotten_potion" &&
                        var_rotten_potion_timer == 0
                    ) {
                        websocket.send(`BREWING_DRINK_ROTTEN_POTION`);
                    } else if (
                        potion == "merchant_speed_potion" &&
                        var_merchant_speed_potion_timer == 0
                    ) {
                        websocket.send(`BREWING_DRINK_MERCHANT_SPEED_POTION`);
                    } else {
                        IdlePixelPlus.sendMessage(`DRINK=${potion}`);
                    }
                }
            },

            initQuickPotions: function () {
                POTIONS.forEach((item) => {
                    const itemBoxes = document.querySelectorAll(`[data-item="${item}"]`);
                    itemBoxes.forEach((itemBox) => {
                        itemBox.oncontextmenu = "";

                        if (itemBox) {
                            itemBox.addEventListener("contextmenu", (event) => {
                                if (getThis.getConfig("quickPotionRightClickEnabled")) {
                                    const primary = sCActionType().primary(event);
                                    const alt = sCActionType().alt(event);
                                    if (primary || alt) {
                                        sCBrewing().quickPotion(item, !primary);
                                        event.stopPropagation();
                                        event.preventDefault();
                                        return false;
                                    }
                                }
                                return true;
                            });
                        }
                    });
                });

                const combatLootPotion = document.querySelector(
                    '[data-item="combat_loot_potion"]'
                );
                combatLootPotion.oncontextmenu = "";

                if (combatLootPotion) {
                    combatLootPotion.addEventListener("contextmenu", (event) => {
                        if (getThis.getConfig("quickPotionRightClickEnabled")) {
                            const primary = sCActionType().primary(event);
                            const alt = sCActionType().alt(event);
                            if (primary || alt) {
                                sCBrewing().quickPotion("combat_loot_potion", !primary);
                                event.stopPropagation();
                                event.preventDefault();
                                return false;
                            }
                        }
                        return true;
                    });
                }

                const merchantSpeedPotion = document.querySelector(
                    '[data-item="merchant_speed_potion"]'
                );
                merchantSpeedPotion.oncontextmenu = "";

                if (merchantSpeedPotion) {
                    merchantSpeedPotion.addEventListener("contextmenu", (event) => {
                        if (getThis.getConfig("quickPotionRightClickEnabled")) {
                            const primary = sCActionType().primary(event);
                            const alt = sCActionType().alt(event);
                            if (primary || alt) {
                                this.quickPotion("merchant_speed_potion", !primary);
                                event.stopPropagation();
                                event.preventDefault();
                                return false;
                            }
                        }
                        return true;
                    });
                }

                const rottenPotion = document.querySelector(
                    '[data-item="rotten_potion"]'
                );
                rottenPotion.oncontextmenu = "";

                if (rottenPotion) {
                    rottenPotion.addEventListener("contextmenu", (event) => {
                        if (getThis.getConfig("quickPotionRightClickEnabled")) {
                            const primary = sCActionType().primary(event);
                            const alt = sCActionType().alt(event);
                            if (primary || alt) {
                                sCBrewing().quickPotion("rotten_potion", !primary);
                                event.stopPropagation();
                                event.preventDefault();
                                return false;
                            }
                        }
                        return true;
                    });
                }
            },

            quickBrew: function (potion) {
                IdlePixelPlus.sendMessage(`BREW=${potion}~1`);
            },

            initQuickBrew: function () {
                const rows = document.querySelectorAll(
                    "#brewing-table tbody tr[data-brewing-item]"
                );
                rows.forEach((row) => {
                    const potion = row.getAttribute("data-brewing-item");
                    if (!potion) {
                        return;
                    }

                    const fourthTd = row.querySelector("td:nth-child(4)");
                    if (fourthTd) {
                        fourthTd.insertAdjacentHTML(
                            "beforeend",
                            `
                            <div class="slapchop-quickbrew-button"
                              onclick="event.stopPropagation(); sCBrewing().quickBrew('${potion}')">Quick Brew 1</div>
                        `
						);
                    }
                });
            },
        };
    };

    const woodcutting = function () {
        window.SCLOGS = Object.keys(Cooking.LOG_HEAT_MAP);

        return {
            quickBurn: function (item, alt) {
                let n = getVar(item, 0, "int");
                singleOverride = getThis.getConfig("autoSingleEnabled");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`ADD_HEAT=${item}~${n}`);
                }
            },

            initQuickBurn: function () {
                SCLOGS.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickBurnRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCWoodcutting().quickBurn(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            initQuickFoundry: function () {
                let html = `
                    <div id="slapchop-quickfoundry" class="slapchop-quickfight">
                        <h5>Quick Foundry:</h5>
                        <div class="slapchop-quicksmelt-buttons">
                    `;
                SCLOGS.forEach((log) => {
                    if (log != "dense_logs") {
                        html += `
                            <button id="slapchop-quickfoundry-${log}" type="button" onclick="sCWoodcutting().quickFoundry('${log}')">
                                <img src="${IMAGE_URL_BASE}/${log}.png" class="img-20" />
                                ${log
                            .replace("_logs", "")
                            .replace(/_/g, " ")
                            .replace(/(^|\s)\w/g, (s) => s.toUpperCase())}
                                (<span data-slap="max-foundry-${log}">?</span>)
                            </button>
                        `;
                    }
                });
                html += `
                        </div>
                        <hr>
                    </div>
                `;

                const panelWoodcutting = document.querySelector(
                    "#panel-woodcutting .panel-logo-xp-area"
                );
                if (panelWoodcutting) {
                    panelWoodcutting.insertAdjacentHTML("afterend", html);
                }
            },

            updateQuickFoundry: function () {
                const foundryBusy = getVar("foundry_amount", 0, "int") != 0;
                SCLOGS.forEach((log) => {
                    if (log != "dense_logs") {
                        const max = sCWoodcutting().maxFoundry(log);
                        const maxFoundryElement = document.querySelector(
                            `[data-slap="max-foundry-${log}"]`
						);
                        if (maxFoundryElement) {
                            maxFoundryElement.textContent = max;
                        }

                        const button = document.querySelector(
                            `#slapchop-quickfoundry-${log}`
						);
                        if (button) {
                            button.disabled = foundryBusy || max <= 0;
                        }
                    }
                });
            },

            quickFoundry: function (log) {
                if (foundryToggle) {
                    foundryToggle = false;
                    const max = sCWoodcutting().maxFoundry(log);
                    if (max > 0) {
                        IdlePixelPlus.sendMessage(`FOUNDRY=${log}~${max}`);
                    }
                    setTimeout(function () {
                        foundryToggle = true;
                    }, 1000);
                }
            },

            maxFoundry: function (log) {
                if (getVar("charcoal_foundry_crafted", "0") != "1") {
                    return 0;
                }
                let max = getVar(log, 0, "int");
                let foundryStorage = getVar("foundry_storage_crafted", 0, "int");

                if (max >= 1000 && foundryStorage == 1) {
                    max = 1000;
                } else if (max > 100 && foundryStorage != 1) {
                    max = 100;
                }

                let oilMax = Math.floor(getVar("oil", 0, "int") / 10);
                if (max > oilMax) {
                    max = oilMax;
                }
                return max;
            },

            initQuickChop: function () {
                const panelWoodcutting = document.querySelector("#panel-woodcutting");
                const firstItembox = panelWoodcutting.querySelector("itembox");

                const lumberjackHtml = `
                    <itembox id="slapchop-lumberjack" class="shadow hover" data-item="slapchop_lumberjack" onclick="sCWoodcutting().quickChop()">
                        <div class="center mt-1"><img width="50" height="50" src=""></div>
                        <div class="center mt-2">Chop</div>
                    </itembox>
                `;
                const rainPotHtml = `
                    <itembox id="slapchop-rain-pot" class="shadow hover" data-item="slapchop_rainpot" onclick="websocket.send('DRINK=rain_potion')">
                        <div class="center mt-1"><img width="50" height="50" src="${IMAGE_URL_BASE}/rain_potion.png" title="rain_potion"></div>
                        <div class="center mt-2">Chop</div>
                    </itembox>
                `;
                const rainPotDivHtml = `
                    <div id="rain_pot-woodcutting" class="lumberjack-rain-pot-woodcutting" data-tooltip="rain_pot">
                        <div class="itembox-fight-center"><img src="${IMAGE_URL_BASE}/rain_potion.png" title="rain_potion"></div>
                        <div class="center-flex">
                            <div id="rain_potion-brew" class="hover" onclick="sCBrewing().quickBrew('rain_potion')">BREW</div>
                            <div id="rain_potion-use" class="hover" onclick="websocket.send('DRINK=rain_potion')">USE</div>
                        </div>
                    </div>
                `;

                if (firstItembox) {
                    firstItembox.insertAdjacentHTML("beforebegin", lumberjackHtml);
                    firstItembox.insertAdjacentHTML("afterend", rainPotHtml);
                    document
                        .querySelector("#slapchop-lumberjack")
                        .insertAdjacentHTML("afterend", rainPotDivHtml);
                }

                const notificationTreesReady = document.querySelector(
                    "#notification-trees-ready"
                );
                if (notificationTreesReady) {
                    if (
                        IdlePixelPlus.plugins.slapchop.getConfig(
                            "quickTreeNotificationHarvestEnabled"
                        )
                    ) {
                        notificationTreesReady.setAttribute(
                            "onClick",
                            "sCWoodcutting().quickChop(); switch_panels('panel-woodcutting')"
                        );
                    } else {
                        notificationTreesReady.setAttribute(
                            "onClick",
                            "switch_panels('panel-woodcutting')"
                        );
                    }
                }
            },

            quickChop: function () {
                for (let i = 1; i <= 5; i++) {
                    let status = getVar("tree_stage_" + i, 0, "int");
                    let treeType = getVar("tree_" + i, "none");
                    let sdCut = getThis.getConfig("quickChopSDTreesEnabled");
                    let regCut = getThis.getConfig("quickChopRegTreesEnabled");
                    if (
                        (status == 4 &&
                         treeType != "stardust_tree" &&
                         treeType != "tree") ||
                        (status == 4 && treeType == "stardust_tree" && sdCut) ||
                        (status == 4 && treeType == "tree" && regCut)
                    ) {
                        IdlePixelPlus.sendMessage("CHOP_TREE=" + i);
                    }
                }
            },
        };
    };

    const cooking = function () {
        window.SCEDIBLES = Object.keys(Cooking.ENERGY_MAP).filter(
            (s) => !s.startsWith("raw_")
        );

        window.SCCOOKABLES = Object.keys(Cooking.FOOD_HEAT_REQ_MAP);

        return {
            initQuickCook: function () {
                SCCOOKABLES.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickCookRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCCooking().quickCook(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            maxCookable: function (food) {
                return Cooking.can_cook_how_many(food) || 0;
            },

            quickCook: function (food, alt) {
                const max = sCCooking().maxCookable(food);
                let n = max;
                if (alt || singleOverride) {
                    const owned = getVar(food, 0, "int");
                    if (owned == max || singleOverride) {
                        n--;
                    }
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`COOK=${food}~${n}`);
                }
            },

            quickEat: function (food, alt) {
                let n = getVar(food, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`CONSUME=${food}~${n}`);
                }
            },

            initQuickEat: function () {
                SCEDIBLES.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickEatRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCCooking().quickEat(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },
        };
    };

    const fishing = function () {
        window.SCBOATS = Array.from(
            document.querySelectorAll(
                `itembox[data-item$="_boat"], itembox[data-item$="_ship"]`
			)
        ).map((el) => el.getAttribute("data-item"));

        window.SCBAITS = Array.from(
            document.querySelectorAll(`itembox[data-item$="bait"]`)
        ).map((el) => el.getAttribute("data-item"));

        return {
            quickBoat: function (item) {
                const n = getVar(`${item}_timer`);
                if (n == "1") {
                    IdlePixelPlus.sendMessage(`BOAT_COLLECT=${item}`);
                } else {
                    IdlePixelPlus.sendMessage(`BOAT_SEND=${item}`);
                }
            },

            initQuickBoat: function () {
                SCBOATS.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickBoatRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCFishing().quickBoat(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            quickBait: function (item) {
                var baitUse = "THROW_" + item.toUpperCase();
                websocket.send(`${baitUse}`);
            },

            initQuickBait: function () {
                SCBAITS.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickBaitRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCFishing().quickBait(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },
        };
    };

    const invention = function () {
        window.SCGRINDABLE = Array.from(
            document.querySelectorAll(
                `#panel-invention itembox[data-item^="blood_"][onclick^="Invention.clicks_limb"]`
			)
        ).map((el) => el.getAttribute("data-item"));

        return {
            initQuickGrind: function () {
                SCGRINDABLE.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickGrindRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCInvention().quickGrind(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            quickGrind: function (item, alt) {
                let n = getVar(item, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (!alt && !singleOverride && n > 1) {
                    n = 1;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`GRIND=${item}~${n}`);
                }
            },

            quickCleanse: function (item, alt) {
                let n = getVar(item, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`CLEANSE_EVIL_BLOOD=${item}~${n}`);
                }
            },

            initQuickCleanse: function () {
                const itembox = document.querySelector(
                    `itembox[data-item="evil_blood"]`
				);
                itembox.addEventListener("contextmenu", (event) => {
                    if (getThis.getConfig("quickCleanseRightClickEnabled")) {
                        const primary = sCActionType().primary(event);
                        const alt = sCActionType().alt(event);
                        if (primary || alt) {
                            sCInvention().quickCleanse("evil_blood", !primary);
                            event.stopPropagation();
                            event.preventDefault();
                            return false;
                        }
                    }
                    return true;
                });
            },
        };
    };

    const combat = function () {
        window.SCNEEDLEABLE = [
            "lizard_mask",
            "lizard_body",
            "lizard_legs",
            "lizard_boots",
            "lizard_gloves",
            "bat_mask",
            "bat_body",
            "bat_legs",
            "bat_boots",
            "bat_gloves",
            "bear_mask",
            "bear_body",
            "bear_legs",
            "bear_boots",
            "bear_gloves",
        ];

        window.SCFEATHER2ARROW = {
            feathers: {
                craft: "wooden_arrows",
                required: {
                    feathers: 15,
                    logs: 5,
                    iron_bar: 5,
                },
            },
            fire_feathers: {
                craft: "fire_arrows",
                required: {
                    fire_feathers: 15,
                    oak_logs: 5,
                    silver_bar: 5,
                },
            },
            ice_feathers: {
                craft: "ice_arrows",
                required: {
                    ice_feathers: 15,
                    willow_logs: 5,
                    gold_bar: 5,
                },
            },
            ancient_feathers: {
                craft: "ancient_arrows",
                required: {
                    ancient_feathers: 15,
                    redwood_logs: 5,
                    ancient_bars: 5,
                },
            },
        };

    window.SCEXPLOSIVES = ["bomb", "tnt", "large_tnt", "mega_bomb"];

    window.SCUSERNAME = getVar("username", "", "string");

    window.SCRINGS = [
        "accuracy_ring",
        "ancient_accuracy_ring",
        "ancient_damage_ring",
        "ancient_defence_ring",
        "damage_ring",
        "defence_ring",
        "good_accuracy_ring",
        "good_damage_ring",
        "good_defence_ring",
        "great_accuracy_ring",
        "great_damage_ring",
        "great_defence_ring",
        "master_ring",
        "perfect_accuracy_ring",
        "perfect_damage_ring",
        "perfect_defence_ring",
        "weak_accuracy_ring",
        "weak_damage_ring",
        "weak_defence_ring",
    ];

    return {
        loadPresets: function (buttonNum) {
            // Retrieve all presets from local storage
            let allPresets =
                JSON.parse(localStorage.getItem(SCUSERNAME + ".combat_presets")) ||
                {};

            // Check if the requested preset exists
            if (!allPresets[buttonNum]) {
                console.error("Preset not found for button number:", buttonNum);
                return;
            }

            // Load the preset and equip each item
            IdlePixelPlus.sendMessage("UNEQUIP_ALL");
            allPresets[buttonNum].forEach((item) => {
                if (item) {
                    IdlePixelPlus.sendMessage("EQUIP=" + item);
                }
            });
        },

        savePresets: function (buttonNum) {
            // Retrieve all presets from local storage, or initialize a new object if none exist
            let allPresets =
                JSON.parse(localStorage.getItem(SCUSERNAME + ".combat_presets")) ||
                {};

            // Save current equipment settings into the relevant key of the allPresets object
            allPresets[buttonNum] = [
                getVar("head", null, "string"),
                getVar("body", null, "string"),
                getVar("legs", null, "string"),
                getVar("boots", null, "string"),
                getVar("gloves", null, "string"),
                getVar("amulet", null, "string"),
                getVar("weapon", null, "string"),
                getVar("shield", null, "string"),
                getVar("arrows", null, "string"),
            ];

            // Update the single entry in local storage with the modified allPresets object
            localStorage.setItem(
                SCUSERNAME + ".combat_presets",
                JSON.stringify(allPresets)
            );
        },

        initQuickFight: async function () {
            let html = `
                    <div id="slapchop-quickfight">
                        <h5>Quick Fight:</h5>
                    <div class="slapchop-quickfight-buttons">
                `;
                Object.values(IdlePixelPlus.info.combatZones).forEach((zone) => {
                    html += `
                        <div id="slapchop-quickfight-${
													zone.id
                }" class="slapchop-quickfight-zone m-1 ${
						zone.blood ? "blood" : ""
                }">
                            <button type="button" onclick="sCCombat().quickFight('${
															zone.id
                }')">${zone.id
                        .replace(/_/g, " ")
                        .replace(/(^|\s)\w/g, (s) => s.toUpperCase())}
                            </button>
                            <div class="slapchop-quickfight-fightpoints slapchop-quickfight-progress-container" title="Fight Points: ${zone.fightPointCost.toLocaleString()}">
                                <span class="slapchop-quickfight-progress-value">0</span>
                                <div class="slapchop-quickfight-progress"></div>
                            </div>
                            <div class="slapchop-quickfight-energy slapchop-quickfight-progress-container" title="Energy: ${zone.energyCost.toLocaleString()}">
                                <span class="slapchop-quickfight-progress-value">0</span>
                                <div class="slapchop-quickfight-progress"></div>
                            </div>
                        </div>
                    `;
                });
                html += `
                    <div id="slapchop-quickfight-pirate" class="slapchop-quickfight-zone m-1 pirate">
                        <button type="button" onclick="websocket.send('FIGHT_EVIL_PIRATE')">Evil Pirate</button>
                        <div class="slapchop-quickfight-fightpoints slapchop-quickfight-progress-container" title="Fight Points: Pirate">
                            <span class="slapchop-quickfight-progress-value">2,000 FP</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                        <div class="slapchop-quickfight-energy slapchop-quickfight-progress-container" title="Evil Pirate Count">
                            <span class="slapchop-quickfight-progress-value">0</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                    </div>
                `;
                html += `
                    <div id="slapchop-quickfight-castle" class="slapchop-quickfight-zone m-1 castle">
                        <button type="button" onclick="Castle.clicks_castle_entrance(); document.getElementById('combat-stats').style.display = 'none'; document.getElementById('game-panels-combat-items-area').style.display = 'none'; Combat.refresh_small_icons_combat_selection();"">Faradox Castle</button>
                        <div class="slapchop-quickfight-fightpoints slapchop-quickfight-progress-container" title="Fight Points: Castle">
                            <span class="slapchop-quickfight-progress-value">No FP to Enter</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                        <div class="slapchop-quickfight-energy slapchop-quickfight-progress-container" title="Energy: Castle">
                            <span class="slapchop-quickfight-progress-value">No Energy to Enter</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                    </div>
                `;
                html += `
                    <div id="slapchop-quickfight-trios" class="slapchop-quickfight-zone m-1 trios">
                        <button type="button" onclick="websocket.send('FIGHT_GUARDIAN=4')">Trio Fight</button>
                        <div class="slapchop-quickfight-fightpoints slapchop-quickfight-progress-container" title="Key Sets: Trios">
                            <span class="slapchop-quickfight-progress-value">0</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                        <div class="slapchop-quickfight-energy slapchop-quickfight-progress-container" title="Energy: Guardian Trios">
                            <span class="slapchop-quickfight-progress-value">100,000 Energy</span>
                            <div class="slapchop-quickfight-progress"></div>
                        </div>
                    </div>
                </div>
                `;
                html += `
                    </div>
                    <hr>
                    </div>
                    <div id="slapchop-quickpreset">
                        <h5>Quick Presets:</h5>
                        <div class="slapchop-quickpreset-buttons">
                        <div>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_SAVE=1')">Save 1</button>
                             <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=1~1')">Load 1</button>
                        </div>
                        <div>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_SAVE=2')">Save 2</button>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=2~1')">Load 2</button>
                        </div>
                        <div>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_SAVE=3')">Save 3</button>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=3~1')">Load 3</button>
                        </div>
                        <div>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_SAVE=4')">Save 4</button>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=4~1')">Load 4</button>
                        </div>
                        <div>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_SAVE=5')">Save 5</button>
                            <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=5~1')">Load 5</button>
                        </div>
                        <div>
                            <button onclick="sCCombat().savePresets(6)">Save 6</button>
                            <button onclick="sCCombat().loadPresets(6)">Load 6</button>
                        </div>
                        <div>
                            <button onclick="sCCombat().savePresets(7)">Save 7</button>
                            <button onclick="sCCombat().loadPresets(7)">Load 7</button>
                        </div>
                        <div>
                            <button onclick="sCCombat().savePresets(8)">Save 8</button>
                            <button onclick="sCCombat().loadPresets(8)">Load 8</button>
                        </div>
                        <div>
                            <button onclick="sCCombat().savePresets(9)">Save 9</button>
                            <button onclick="sCCombat().loadPresets(9)">Load 9</button>
                        </div>
                        <div>
                            <button onclick="sCCombat().savePresets(10)">Save 10</button>
                            <button onclick="sCCombat().loadPresets(10)">Load 10</button>
                        </div>
                    </div>
                    <br>
                    <h5>Rings:</h5>
                    <div>
                        <button onclick="sCCombat().equipAllRings()">All</button>
                        <button onclick="sCCombat().unEquipAllRings()">None</button>
                        <hr>
                    </div>
                `;
                const panelCombat = document.getElementById("combat-stats").querySelectorAll("div")[4];
                if (panelCombat) {
                    panelCombat.insertAdjacentHTML("afterend", html);
                }

                const gamePanelsCombatItemsArea = document.getElementById(
                    "itembox-fight-guardians"
                );
                if (gamePanelsCombatItemsArea) {
                    gamePanelsCombatItemsArea.insertAdjacentHTML(
                        "afterend",
                        `
                        <div id="rare-monster-pot-in-combat-tab" class="itembox-fight" data-tooltip="fight">
                            <div class="itembox-fight-center"><img src="${IMAGE_URL_BASE}/rare_monster_potion.png" title="fight"></div>
                            <div class="center-flex">
                                <div id="rare_monster_potion-brew" class="hover" onclick="sCBrewing().quickBrew('rare_monster_potion')">BREW</div>
                                <div id="rare_monster_potion-use" class="hover" onclick="Modals.clicks_rare_monster_potion()">USE</div>
                            </div>
                        </div>
                    `
					);
                }

                const rareMonsterPotInCombatTab = document.querySelector(
                    "#rare-monster-pot-in-combat-tab"
                );
                if (rareMonsterPotInCombatTab) {
                    rareMonsterPotInCombatTab.insertAdjacentHTML(
                        "afterend",
                        `
                        <div id="super_rare-monster-pot-in-combat-tab" class="itembox-fight" data-tooltip="fight">
                            <div class="itembox-fight-center"><img src="${IMAGE_URL_BASE}/super_rare_monster_potion.png" title="fight"></div>
                            <div class="center-flex">
                                <div id="super_rare_monster_potion-brew" class="hover" onclick="sCBrewing().quickBrew('super_rare_monster_potion')">BREW</div>
                                <div id="super_rare_monster_potion-use" class="hover" onclick="Modals.clicks_super_rare_monster_potion()">USE</div>
                            </div>
                        </div>
                    `
					);
                }

                const fightLeftBorderCombatBottomPanel = document.querySelector(
                    ".fight-left-border .td-combat-bottom-panel"
                );
                if (fightLeftBorderCombatBottomPanel) {
                    fightLeftBorderCombatBottomPanel.insertAdjacentHTML(
                        "afterend",
                        `
                        <div id="fighting-combat_loot_potion" onclick="websocket.send('BREWING_DRINK_COMBAT_LOOT_POTION')" class="fighting-monster-loot-potion hover shadow">
                            <img src="https://idlepixel.s3.us-east-2.amazonaws.com/images/combat_loot_potion.png" title="combat_loot_potion_icon">
                            <span id="combat_loot_potion-label">Loot Potions: 0</span>
                        </div>
                    `
					);
                }

                const fightLeftBorderFightingCombatLootPotion = document.querySelector(
                    ".fight-left-border #fighting-combat_loot_potion"
                );
                if (fightLeftBorderFightingCombatLootPotion) {
                    fightLeftBorderFightingCombatLootPotion.insertAdjacentHTML(
                        "afterend",
                        `
                        <div id="fighting-rain_potion" onclick="websocket.send('DRINK=rain_potion')" class="fighting-monster-rain-potion hover shadow">
                            <img src="https://idlepixel.s3.us-east-2.amazonaws.com/images/rain_potion.png" title="rain_potion_in_combat_icon">
                            <span id="rain_potion-in-combat-label">Rain Potions: 0</span>
                        </div>
                    `
					);
                }
            },

            useLamps: function (typeLamp) {
                var lampCount = getVar("combat_xp_lamp", 0, "int");
                for (let i = lampCount; i > 0; i--) {
                    websocket.send("COMBAT_XP_LAMP=" + typeLamp);
                }
            },

            initQuickLamps: function () {
                const quickLampContainerHtml = `
                    <div id="quick-lamp-container">
                        <div id="quick-lamp-zone">
                            <h5>Quick Lamps:</h5>
                            <div id="lamp-zone-all">
                                <div id="melee-lamp-zone">
                                    <div id="melee-zone-label">Melee</div>
                                    <button id="lamp-melee-max" onclick="sCCombat().useLamps('melee')">Max</button>
                                </div>
                                <div id="archery-lamp-zone">
                                    <div id="archery-zone-label">Archery</div>
                                    <button id="lamp-archery-max" onclick="sCCombat().useLamps('archery')">Max</button>
                                </div>
                                <div id="magic-lamp-zone">
                                    <div id="magic-zone-label">Magic</div>
                                    <button id="lamp-magic-max" onclick="sCCombat().useLamps('magic')">Max</button>
                                </div>
                            </div>
                        </div>
                        <hr>
                    </div>
                `;

                const gamePanelsCombatItemsArea = document.querySelector(
                    "#game-panels-combat-items-area"
                );
                if (gamePanelsCombatItemsArea) {
                    gamePanelsCombatItemsArea.insertAdjacentHTML(
                        "beforebegin",
                        quickLampContainerHtml
                    );
                }

                const lamps = getVar("combat_xp_lamp", 0, "int");
                const quickLampContainer = document.getElementById("quick-lamp-container");
                if (quickLampContainer) {
                    if (lamps === 0) {
                        quickLampContainer.style.display = "none";
                    } else {
                        quickLampContainer.style.display = "block";
                    }
                }
            },

            updateQuickFight: function () {
                const fp = getVar("fight_points", 0, "int");
                const energy = getVar("energy", 0, "int");
                const evilPirate = getVar("evil_pirate", 0, "int");
                const g1Key = getVar("green_gaurdian_key", 0, "int");
                const g2Key = getVar("blue_gaurdian_key", 0, "int");
                const g3Key = getVar("purple_gaurdian_key", 0, "int");
                const maxTrio = Math.min(g1Key, g2Key, g3Key);

                Object.values(IdlePixelPlus.info.combatZones).forEach((zone) => {
                    let disabled = fp < zone.fightPointCost || energy < zone.energyCost;
                    let disabledPirate = fp < 2000 || evilPirate == 0;
                    let disabledTrios = energy < 100000 || maxTrio == 0;
                    let fpPercent = (fp / zone.fightPointCost).toFixed(2).split(".");
                    let fpPiratePercent = (fp / 2000).toFixed(2).split(".");
                    let energyPercent = (energy / zone.energyCost).toFixed(2).split(".");
                    let trioEnergyPercent = (energy / 100000).toFixed(2).split(".");

                    let fpLabel = `&times; ${fpPercent[0]} + ${fpPercent[1].replace(
                        /^0/,
                        ""
                    )}%`;
                    let fpPirateLabel = `&times; ${
						fpPiratePercent[0]
                    } + ${fpPiratePercent[1].replace(/^0/, "")}%`;
                    let energyTrioLabel = `&times; ${
						trioEnergyPercent[0]
                    } + ${trioEnergyPercent[1].replace(/^0/, "")}%`;
                    let energyLabel = `&times; ${
						energyPercent[0]
                    } + ${energyPercent[1].replace(/^0/, "")}%`;

                    if (
                        zone.id === "volcano" &&
                        IdlePixelPlus.getVar("volcano_unlocked") !== "1"
                    ) {
                        disabled = true;
                    } else if (
                        zone.id === "northern_field" &&
                        IdlePixelPlus.getVar("northern_field_unlocked") !== "1"
                    ) {
                        disabled = true;
                    } else if (
                        zone.id === "mansion" &&
                        IdlePixelPlus.getVar("mansion_unlocked") !== "1"
                    ) {
                        disabled = true;
                    } else if (
                        (zone.id === "blood_field" ||
                         zone.id === "blood_forest" ||
                         zone.id === "blood_cave" ||
                         zone.id === "blood_volcano") &&
                        IdlePixelPlus.getVar("blood_moon_active") !== "1"
                    ) {
                        disabled = true;
                    }

                    const button = document.querySelector(
                        `#slapchop-quickfight-${zone.id} button`
					);
                    button.disabled = disabled;

                    const fpProgress = document.querySelector(
                        `#slapchop-quickfight-${zone.id} .slapchop-quickfight-fightpoints .slapchop-quickfight-progress`
					);
                    const energyProgress = document.querySelector(
                        `#slapchop-quickfight-${zone.id} .slapchop-quickfight-energy .slapchop-quickfight-progress`
					);
                    const fpProgressValue = document.querySelector(
                        `#slapchop-quickfight-${zone.id} .slapchop-quickfight-fightpoints .slapchop-quickfight-progress-value`
					);
                    const energyProgressValue = document.querySelector(
                        `#slapchop-quickfight-${zone.id} .slapchop-quickfight-energy .slapchop-quickfight-progress-value`
					);
                    const fpProgressPirate = document.querySelector(
                        `#slapchop-quickfight-pirate .slapchop-quickfight-fightpoints .slapchop-quickfight-progress`
					);
                    const fpPirateProgressValue = document.querySelector(
                        `#slapchop-quickfight-pirate .slapchop-quickfight-fightpoints .slapchop-quickfight-progress-value`
					);
                    const energyPirateProgressValue = document.querySelector(
                        `#slapchop-quickfight-pirate .slapchop-quickfight-energy .slapchop-quickfight-progress-value`
					);
                    const energyTrioProgressValue = document.querySelector(
                        `#slapchop-quickfight-trios .slapchop-quickfight-energy .slapchop-quickfight-progress-value`
					);
                    const fpTrioProgressValue = document.querySelector(
                        `#slapchop-quickfight-trios .slapchop-quickfight-fightpoints .slapchop-quickfight-progress-value`
					);

                    const buttonPirate = document.querySelector(
                        `#slapchop-quickfight-pirate button`
					);
                    const buttonTrios = document.querySelector(
                        `#slapchop-quickfight-trios button`
					);
                    buttonPirate.disabled = disabledPirate;

                    buttonTrios.disabled = disabledTrios;

                    fpProgress.style.width = `${fpPercent}%`;
                    fpProgressPirate.style.width = `${fpPiratePercent}%`;
                    energyProgress.style.width = `${energyPercent}%`;
                    fpProgressValue.innerHTML = fpLabel;
                    fpPirateProgressValue.innerHTML = fpPirateLabel;
                    fpTrioProgressValue.innerHTML = `${maxTrio} Remaining`;

                    energyProgressValue.innerHTML = energyLabel;
                    energyPirateProgressValue.innerHTML = `${evilPirate} Remaining`;
                    energyTrioProgressValue.innerHTML = energyTrioLabel;

                });
            },

            quickFight: function (zoneId) {
                const confirm = getThis.getConfig("quickFightConfirm");
                if (confirm) {
                    if (
                        sCCombat().confirm(
                            `FIGHT: ${zoneId
                            .replace(/_/g, " ")
                            .replace(/(^|\s)\w/g, (s) => s.toUpperCase())} ?`
						)
                    ) {
                        if (zoneId.startsWith("blood_")) {
                            Combat.modal_blood_area_last_selected = zoneId;
                        } else {
                            Combat.modal_area_last_selected = zoneId;
                        }
                        IdlePixelPlus.sendMessage(`START_FIGHT=${zoneId}`);
                    }
                } else {
                    if (zoneId.startsWith("blood_")) {
                        Combat.modal_blood_area_last_selected = zoneId;
                    } else {
                        Combat.modal_area_last_selected = zoneId;
                    }
                    IdlePixelPlus.sendMessage(`START_FIGHT=${zoneId}`);
                }
            },

            quickExplode: function (item) {
                IdlePixelPlus.sendMessage(`USE_${item.toUpperCase()}`);
            },

            initQuickExplode: function () {
                SCEXPLOSIVES.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickExplosionEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCCombat().quickExplode(item);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            quickNeedle: function (item, alt) {
                let n = getVar(item, 0, "int");
                if (alt || singleOverride) {
                    n--;
                }
                if (n > 0) {
                    IdlePixelPlus.sendMessage(`USE_NEEDLE=${item}~${n}`);
                }
            },

            initQuickNeedle: function () {
                SCNEEDLEABLE.forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickNeedleRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCCombat().quickNeedle(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            maxCraftableArrows: function (feather) {
                const data = SCFEATHER2ARROW[feather];
                if (!data) return 0;

                let max = Number.MAX_SAFE_INTEGER;
                Object.keys(data.required).forEach((item) => {
                    const needed = data.required[item];
                    const owned = getVar(item, 0, "int");
                    const craftable = Math.floor(owned / needed);
                    max = Math.min(max, craftable);
                });
                return max;
            },

            quickFeather2Arrow: function (item, alt) {
                let n = sCCombat().maxCraftableArrows(item);
                if (n > 0) {
                    IdlePixelPlus.sendMessage(
                        `CRAFT=${SCFEATHER2ARROW[item].craft}~${n}`
					);
                }
            },

            initQuickFeather2Arrow: function () {
                Object.keys(SCFEATHER2ARROW).forEach((item) => {
                    const itemboxes = document.querySelectorAll(
                        `itembox[data-item="${item}"]`
					);
                    itemboxes.forEach((itembox) => {
                        itembox.addEventListener("contextmenu", (event) => {
                            if (getThis.getConfig("quickCraftArrowRightClickEnabled")) {
                                const primary = sCActionType().primary(event);
                                const alt = sCActionType().alt(event);
                                if (primary || alt) {
                                    sCCombat().quickFeather2Arrow(item, !primary);
                                    event.stopPropagation();
                                    event.preventDefault();
                                    return false;
                                }
                            }
                            return true;
                        });
                    });
                });
            },

            initPresets: function () {
                const combatPresetsHtml = `
                    <br />
                    <br />
                    <img data-tooltip="Preset 6" id="in-combat-presets-icon-6" onclick="sCCombat().loadPresets(6)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" />
                    <img data-tooltip="Preset 7" id="in-combat-presets-icon-7" onclick="sCCombat().loadPresets(7)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" />
                    <img data-tooltip="Preset 8" id="in-combat-presets-icon-8" onclick="sCCombat().loadPresets(8)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" />
                    <img data-tooltip="Preset 9" id="in-combat-presets-icon-9" onclick="sCCombat().loadPresets(9)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" />
                    <img data-tooltip="Preset 10" id="in-combat-presets-icon-10" onclick="sCCombat().loadPresets(10)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" />
                    <br />
                    <br />
                    <img id="in-combat-presets-equip-rings" onclick="sCCombat().equipAllRings()" class="combat-presets-combat-icon hover w30" style="background-color: darkgreen" src="${IMAGE_URL_BASE}/rings_icon.png" title="Equip All Rings">
                    <img id="in-combat-presets-unequip-rings" onclick="sCCombat().unEquipAllRings()" class="combat-presets-combat-icon hover w30" style="background-color: darkred" src="${IMAGE_URL_BASE}/rings_icon.png" title="All Rings">
                `;

                const combatPresetsArea = document.getElementById(
                    "combat-presets-area"
                );
                if (combatPresetsArea) {
                    combatPresetsArea.insertAdjacentHTML("beforeend", combatPresetsHtml);
                }
            },

            initPresetListener: function () {
                const KEY_ACTIONS = {
                    54: () => sCCombat().loadPresets(6),
                    55: () => sCCombat().loadPresets(7),
                    56: () => sCCombat().loadPresets(8),
                    57: () => sCCombat().loadPresets(9),
                    48: () => sCCombat().loadPresets(10),
                    189: () => sCCombat().equipAllRings(),
                    187: () => sCCombat().unEquipAllRings(),
                };

                document.addEventListener("keyup", (e) => {
                    const chatInput = document.getElementById("chat-area-input");
                    let chatFocused = chatInput && document.activeElement === chatInput;
                    let isRelevantPanel = [
                        "panel-combat-canvas",
                        "panel-combat",
                        "panel-combat-canvas-raids",
                    ].includes(Globals.currentPanel);

                    if (chatFocused || !isRelevantPanel) {
                        return; // Early exit if chat is focused or the panel is not relevant
                    }

                    const action = KEY_ACTIONS[e.keyCode];
                    if (action) {
                        action(); // Execute the action associated with the key code
                    }
                });
            },

            equipAllRings: function () {
                SCRINGS.forEach((ring) => {
                    if (
                        getVar(ring, 0, "int") != 0 &&
                        getVar(ring + "_equipped", 0, "int") == 0 &&
                        (getVar(ring + "_crafted", 0, "int") == 1 ||
                         getVar(ring + "_assembled", 0, "int") == 1)
                    ) {
                        IdlePixelPlus.sendMessage(`EQUIP_RING=${ring}`);
                    }
                });
            },

            unEquipAllRings: function () {
                SCRINGS.forEach((ring) => {
                    if (getVar(ring + "_equipped", 0, "int") == 1) {
                        IdlePixelPlus.sendMessage(`EQUIP_RING=${ring}`);
                    }
                });
            },
        };
    };

    window.sCMisc = misc;
    window.sCActionType = actionType;
    window.sCMiningCrafting = mining_crafting;
    window.sCGathering = gathering;
    window.sCFarming = farming;
    window.sCBrewing = brewing;
    window.sCWoodcutting = woodcutting;
    window.sCCooking = cooking;
    window.sCFishing = fishing;
    window.sCInvention = invention;
    window.sCCombat = combat;

    // End New Code Base Const/Functions

    class SlapChopPlugin extends IdlePixelPlusPlugin {
        constructor() {
            super("slapchop", {
                about: {
                    name: GM_info.script.name + " (ver: " + GM_info.script.version + ")",
                    version: GM_info.script.version,
                    author: GM_info.script.author,
                    description: GM_info.script.description,
                },
                config: [
                    {
                        label:
                        "------------------------------------------------<br/>Key Binds<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "primaryActionKey",
                        label: "Primary Action Key",
                        type: "select",
                        options: [
                            { value: "none", label: "None" },
                            { value: "altKey", label: "Alt" },
                            { value: "shiftKey", label: "Shift" },
                            { value: "ctrlKey", label: "Ctrl" },
                        ],
                        default: "none",
                    },
                    {
                        id: "altActionKey",
                        label: "Alt Action Key",
                        type: "select",
                        options: [
                            { value: "altKey", label: "Alt" },
                            { value: "shiftKey", label: "Shift" },
                            { value: "ctrlKey", label: "Ctrl" },
                        ],
                        default: "altKey",
                    },
                    {
                        id: "autoSingleEnabled",
                        label:
                        "Enable the ability to use items without having to hold the 'ALT' key<br/>to keep a single item for slapchop commands.",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Brewing<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickBrewButtonEnabled",
                        label: "Quick Brew (buttons): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickPotionRightClickEnabled",
                        label: "Quick Potion (right-click, primary=1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Combat<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickCraftArrowRightClickEnabled",
                        label:
                        "Quick Craft Arrow (right-click feather, primary=max): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickExplosionEnabled",
                        label:
                        "Quick Detonation - Quickly use explosives in combat window (right-click): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickFightEnabled",
                        label: "Quick Fight: Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickFightConfirm",
                        label: "Quick Fight: Confirm",
                        type: "boolean",
                        default: false,
                    },
                    {
                        id: "quickFightEnergyBar",
                        label: "Quick Fight: Energy Bar",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickFightFPBar",
                        label: "Quick Fight: FP Bar",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickLampShow",
                        label: "Quick Lamp Show (When you have Lamps)",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickNeedleRightClickEnabled",
                        label:
                        "Quick Needle (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: false,
                    },
                    {
                        id: "quickPresetsEnabled",
                        label: "Quick Presets: Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Cooking/Eating<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickCookRightClickEnabled",
                        label: "Quick Cook (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickEatRightClickEnabled",
                        label: "Quick Eat (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Farming<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickBoneRightClickEnabled",
                        label:
                        "Quick Bonemeal (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickHarvestEnabled",
                        label: "Quick Harvest (Bob): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickHarvestNotificationEnabled",
                        label:
                        "Harvest Farm plots when clicking on the notification: Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickPlantRightClickEnabled",
                        label: "Quick Plant (right-click, primary=1, alt=max): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickPlantHarvestRightClickEnabled",
                        label:
                        "Quick Harvest And Plant (right-click, primary=1, alt=max): Enabled",
                        type: "boolean",
                        default: false,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Fishing<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickBaitRightClickEnabled",
                        label: "Quick Bait (right-click): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickBoatRightClickEnabled",
                        label: "Quick Boat (right-click): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Foundry/Mining/Smelting<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickFoundryEnabled",
                        label: "Quick Foundry (buttons): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickMiningRightClickEnabled",
                        label: "Quick Geode / Prism Use (right-click, primary=1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickMineralRightClickEnabled",
                        label:
                        "Quick Mineral XP Conversion (right-click, primary=1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickSmeltEnabled",
                        label: "Quick Smelt (buttons): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickSmeltRightClickEnabled",
                        label: "Quick Smelt (right-click, primary=max): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Gathering<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickGatherRightClickEnabled",
                        label:
                        "Quick Gather (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Invention<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickGrindRightClickEnabled",
                        label: "Quick Blood Grind (right-click, primary=1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickCleanseRightClickEnabled",
                        label:
                        "Quick Cleanse Blood in Invention (right-click, primary=1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        label:
                        "------------------------------------------------<br/>Woodcutting<br/>------------------------------------------------",
                        type: "label",
                    },
                    {
                        id: "quickBurnRightClickEnabled",
                        label:
                        "Quick Burn Logs (right-click, primary=max, alt=keep-1): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickChopEnabled",
                        label: "Quick Chop (Lumberjack): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickChopRegTreesEnabled",
                        label: "Quick Chop (Normal Trees Lumberjack): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickChopSDTreesEnabled",
                        label: "Quick Chop (SD Trees Lumberjack): Enabled",
                        type: "boolean",
                        default: true,
                    },
                    {
                        id: "quickTreeNotificationHarvestEnabled",
                        label: "Harvest Trees when clicking on the notification: Enabled",
                        type: "boolean",
                        default: true,
                    },
                ],
            });
        }

        onPanelChanged(panelBefore, panelAfter) {
            if (Globals.currentPanel == "panel-woodcutting") {
                let woodCuttingElite = Achievements.has_completed_set(
                    "woodcutting",
                    "elite"
                );
                if (woodCuttingElite) {
                    document.getElementById("rain_pot-woodcutting").style.display = "";
                } else {
                    document.getElementById("rain_pot-woodcutting").style.display =
                        "none";
                }
                if (Globals.currentPanel == "panel-combat") {
                    var lamps = getVar("combat_xp_lamp", 0, "int");
                    if (lamps == 0) {
                        document.getElementById("quick-lamp-container").style.display =
                            "none";
                    } else {
                        document.getElementById("quick-lamp-container").style.display = "";
                    }
                    sCMisc().updateQuickFight();
                }
            }
        }

        onConfigsChanged() {
            if (onLoginLoaded) {
                sCMisc().updateButtons();

                const slapchopQuickFight = document.querySelector(
                    "#slapchop-quickfight"
                );
                const slapchopQuickFoundry = document.querySelector(
                    "#slapchop-quickfoundry"
                );
                const slapchopQuickPreset = document.querySelector(
                    "#slapchop-quickpreset"
                );
                const slapchopQuickFightFPBar = document.querySelectorAll(
                    ".slapchop-quickfight-fightpoints"
                );
                const slapchopQuickFightEnergyBar = document.querySelectorAll(
                    ".slapchop-quickfight-energy"
                );
                const slapchopQuickSmeltMining = document.getElementById(
                    "slapchop-quicksmelt-mining"
                );
                const slapchopQuickSmeltCrafting = document.getElementById(
                    "slapchop-quicksmelt-crafting"
                );
                const slapchopQuickBrewButton = document.querySelectorAll(
                    ".slapchop-quickbrew-button"
                );

                singleOverride = getThis.getConfig("autoSingleEnabled");

                if (getThis.getConfig("quickFightEnabled")) {
                    slapchopQuickFight.style.display = "block";
                } else {
                    slapchopQuickFight.style.display = "none";
                }

                if (getThis.getConfig("quickFoundryEnabled")) {
                    slapchopQuickFoundry.style.display = "block";
                } else {
                    slapchopQuickFoundry.style.display = "none";
                }

                const presetsUnlocked = IdlePixelPlus.getVar("combat_presets") == "1";
                if (presetsUnlocked && getThis.getConfig("quickPresetsEnabled")) {
                    slapchopQuickPreset.style.display = "block";
                } else {
                    slapchopQuickPreset.style.display = "none";
                }

                if (getThis.getConfig("quickFightFPBar")) {
                    slapchopQuickFightFPBar.forEach((bar) => {
                        bar.style.display = "block";
                    });
                } else {
                    slapchopQuickFightFPBar.forEach((bar) => {
                        bar.style.display = "none";
                    });
                }

                if (getThis.getConfig("quickFightEnergyBar")) {
                    slapchopQuickFightEnergyBar.forEach((bar) => {
                        bar.style.display = "block";
                    });
                } else {
                    slapchopQuickFightEnergyBar.forEach((bar) => {
                        bar.style.display = "none";
                    });
                }

                if (getThis.getConfig("quickSmeltEnabled")) {
                    slapchopQuickSmeltMining.style.display = "block";
                    slapchopQuickSmeltCrafting.style.display = "block";
                } else {
                    slapchopQuickSmeltMining.style.display = "none";
                    slapchopQuickSmeltCrafting.style.display = "none";
                }

                if (getThis.getConfig("quickBrewButtonEnabled")) {
                    slapchopQuickBrewButton.forEach((button) => {
                        button.style.display = "block";
                    });
                } else {
                    slapchopQuickBrewButton.forEach((button) => {
                        button.style.display = "none";
                    });
                }

                if (
                    getThis.getConfig("quickLampShow") &&
                    getVar("combat_xp_lamp", 0, "int") > 0
                ) {
                    document.getElementById("quick-lamp-container").style.display = "";
                } else {
                    document.getElementById("quick-lamp-container").style.display =
                        "none";
                }

                if (getThis.getConfig("quickHarvestEnabled")) {
                    window.var_slapchop_bob = "1";
                } else {
                    window.var_slapchop_bob = "0";
                }

                if (getThis.getConfig("quickChopEnabled")) {
                    window.var_slapchop_lumberjack = "1";
                } else {
                    window.var_slapchop_lumberjack = "0";
                }

                const notificationTreesReady = document.getElementById(
                    "notification-trees"
                );
                if (getThis.getConfig("quickTreeNotificationHarvestEnabled")) {
                    notificationTreesReady.setAttribute(
                        "onClick",
                        `sCWoodcutting().quickChop(); switch_panels('panel-woodcutting')`
					);
                } else {
                    notificationTreesReady.setAttribute(
                        "onClick",
                        `switch_panels('panel-woodcutting')`
					);
            }
            }
        }

        onLogin() {
            IPP = IdlePixelPlus;
            getVar = IdlePixelPlus.getVarOrDefault;
            getThis = IdlePixelPlus.plugins.slapchop;
            singleOverride = getThis.getConfig("autoSingleEnabled");
            sCMisc().initStyles();
            sCCombat().initQuickFight();
            sCMiningCrafting().initQuickSmelt();
            sCCooking().initQuickCook();
            sCCooking().initQuickEat();
            sCFarming().initQuickPlant();
            sCFarming().initQuickBones();
            sCBrewing().initQuickPotions();
            sCFishing().initQuickBoat();
            sCFishing().initQuickBait();
            sCCombat().initQuickNeedle();
            sCBrewing().initQuickBrew();
            sCGathering().initQuickGather();
            sCWoodcutting().initQuickBurn();
            sCCombat().initQuickFeather2Arrow();
            sCWoodcutting().initQuickFoundry();
            sCWoodcutting().initQuickChop();
            sCFarming().initQuickHarvest();
            sCInvention().initQuickGrind();
            sCMiningCrafting().initQuickRocketFuel();
            sCMiningCrafting().initQuickMining();
            sCInvention().initQuickCleanse();
            sCMiningCrafting().initQuickMineral();
            sCMiningCrafting().initMiningPresets();
            sCCombat().initPresets();
            sCCombat().initPresetListener();
            sCCombat().initQuickExplode();
            sCCombat().initQuickLamps();

            sCCombat().updateQuickFight();
            sCMiningCrafting().updateQuickSmelt();
            sCWoodcutting().updateQuickFoundry();

            setTimeout(function () {
                onLoginLoaded = true;
                IdlePixelPlus.plugins.slapchop.onConfigsChanged();
            }, 5000);
            loaded = true;
        }

        onVariableSet(key, valueBefore, valueAfter) {
            if (onLoginLoaded) {
                if (Globals.currentPanel != "panel-combat-canvas") {
                    if (Globals.currentPanel == "panel-combat") {
                        if (key.includes("combat_xp_lamp")) {
                            var lamps = getVar("combat_xp_lamp", 0, "int");
                            if (lamps == 0 || !getThis.getConfig("quickLampShow")) {
                                document.getElementById("quick-lamp-container").style.display =
                                    "none";
                            } else {
                                document.getElementById("quick-lamp-container").style.display =
                                    "";
                            }
                        }
                    }
                    if (
                        [
                            "fight_points",
                            "energy",
                            "volcano_unlocked",
                            "northern_field_unlocked",
                            "blood_moon_active",
                        ].includes(key)
                    ) {
                        sCCombat().updateQuickFight();
                    }
                }

                if (
                    Globals.currentPanel == "panel-mining" ||
                    Globals.currentPanel == "panel-crafting"
                ) {
                    if (
                        [
                            SCSMELTABLES,
                            "oil",
                            "charcoal",
                            "lava",
                            "dragon_fire",
                            "stone_furnace",
                            "bronze_furnace",
                            "iron_furnace",
                            "silver_furnace",
                            "gold_furnace",
                            "promethium_furnace",
                            "titanium_furnace",
                            "ancient_furnace",
                            "dragon_furnace",
                        ].includes(key)
                    ) {
                        sCMiningCrafting().updateQuickSmelt();
                        sCMiningCrafting().updateMaxCraftable();
                    }
                }

                if (Globals.currentPanel == "panel-woodcutting") {
                    if ([SCLOGS, "oil", "foundry_amount"].includes(key)) {
                        sCWoodcutting().updateQuickFoundry();
                    }
                }

                if (!loaded) {
                    this.delay();
                    return;
                }

                let variables = [
                    "dotted_green_leaf",
                    "strange_leaf",
                    "red_mushroom",
                    "rare_monster_potion",
                    "super_rare_monster_potion",
                    "combat_loot_potion",
                    "combat_loot_potion_timer",
                    "rain_potion",
                    "rain_potion_timer",
                ];
                if (variables.includes(key)) {
                    sCMisc().updateButtons();
                }
            }
        }

        async delay() {
            await new Promise((resolve) => {
                const checkLoaded = () => {
                    if (loaded) {
                        resolve();
                    } else {
                        setTimeout(checkLoaded, 2000);
                    }
                };

                checkLoaded();
            });

            sCMisc().updateButtons();
        }
    }

    const plugin = new SlapChopPlugin();
    IdlePixelPlus.registerPlugin(plugin);
})();