您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Ain't nobody got time for that! Adds some QoL 1-click actions.
// ==UserScript== // @name IdlePixel Slap Chop - mippo Fork // @namespace com.anwinity.idlepixel // @version 3.1.1 // @description Ain't nobody got time for that! Adds some QoL 1-click actions. // @author Original Author: Anwinity || Modded By: GodofNades || Modded By: mippo // @license MIT // @match *://idle-pixel.com/login/play* // @grant none // @require https://gf.qytechs.cn/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; } #combat-stats #slapchop-quickpreset > .slapchop-quickpreset-buttons { display: grid; grid-template-columns: auto auto; justify-content: start; column-gap: 1em; } #combat-stats #slapchop-quickpreset > .slapchop-quickpreset-buttons > div { display: flex; flex-direction: row; justify-content: flex-start; } #combat-stats #slapchop-quickpreset > .slapchop-quickpreset-buttons > div > div { display: flex; flex-direction: column; justify-content: flex-start; } #slapchop-quickpreset-buttons-unlink, #slapchop-quickpreset-buttons-unlink-lock { font-size: 0.8em; } #slapchop-quickpreset-buttons-unlink.current-group-0, #slapchop-quickpreset-buttons-unlink-lock.current-group-99, #combat-stats #slapchop-quickpreset-buttons-groups.current-group-6 > .slapchop-quickpreset-buttons-group6 > button, #combat-stats #slapchop-quickpreset-buttons-groups.current-group-7 > .slapchop-quickpreset-buttons-group7 > button, #combat-stats #slapchop-quickpreset-buttons-groups.current-group-8 > .slapchop-quickpreset-buttons-group8 > button, #combat-stats #slapchop-quickpreset-buttons-groups.current-group-9 > .slapchop-quickpreset-buttons-group9 > button, #combat-stats #slapchop-quickpreset-buttons-groups.current-group-10 > .slapchop-quickpreset-buttons-group10 > button, #in-combat-presets-icon-6.current, #in-combat-presets-icon-7.current, #in-combat-presets-icon-8.current, #in-combat-presets-icon-9.current, #in-combat-presets-icon-10.current { background-color: limegreen; } #slapchop-quickpreset button { margin: 0.125em; } .combat-presets-area, .combat-potions-area, .combat-cannon-area { vertical-align: text-top; } #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; vertical-align: text-top; 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; margin-bottom: 15px; } #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[data-item=green_leaf_buddy]"); 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; } } else { // Open default right-click menu Modals.open_brew_dialogue(itemBox.getAttribute('data-item')); event.stopPropagation(); event.preventDefault(); return false; } }); } }); }); 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; } } else { // Open default right-click menu Modals.open_brew_dialogue(combatLootPotion.getAttribute('data-item')); event.stopPropagation(); event.preventDefault(); return false; } }); } 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; } } else { // Open default right-click menu Modals.open_brew_dialogue(merchantSpeedPotion.getAttribute('data-item')); event.stopPropagation(); event.preventDefault(); return false; } }); } 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; } } else { // Open default right-click menu Modals.open_brew_dialogue(rottenPotion.getAttribute('data-item')); event.stopPropagation(); event.preventDefault(); return false; } }); } }, 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[data-item=chop_all_ent_special]"); 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("afterend", 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", ]; // Define keys for localStorage in a centralized manner const COMBAT_PRESETS_KEY = SCUSERNAME + ".combat_presets"; const COMBAT_PRESETS_LINK_KEY = SCUSERNAME + ".combat_presets_link"; return { loadPresetGroups: function (buttonNum) { // Suppress popup "Combat preset saved" const openImageModalOriginal = Modals.open_image_modal; Modals.open_image_modal = (title, image_path, message, primary_button_text, secondary_button_text, command, force_unclosable) => { if (message === "Successfully saved preset based on what you are currently wearing.") { return; } openImageModalOriginal(title, image_path, message, primary_button_text, secondary_button_text, command, force_unclosable); } // Set shortcut number presets to 1-5 for (let combatpresetNum = 1; combatpresetNum < 6; combatpresetNum++) { let presetName = `CombatPreset ${buttonNum * 10 + combatpresetNum}`; // Retrieve all presets from local storage let allPresets = JSON.parse(localStorage.getItem(COMBAT_PRESETS_KEY)) || {}; // Check if the requested preset exists if (!allPresets[presetName]) { console.error("Preset not found for button number:", presetName); return; } // Load the preset and equip each item IdlePixelPlus.sendMessage("UNEQUIP_ALL"); allPresets[presetName].forEach((item) => { if (item) { IdlePixelPlus.sendMessage("EQUIP=" + item); } }); IdlePixelPlus.sendMessage(`PRESET_SAVE=${combatpresetNum}`); } IdlePixelPlus.sendMessage('PRESET_LOAD=1~1'); sCCombat().saveLinkedPresetNum(buttonNum); }, savePresetGroups: function (buttonNum) { // Presets 1-5 are saved as shortcut numbers for (let combatpresetNum = 1; combatpresetNum < 6; combatpresetNum++) { let presetName = `CombatPreset ${buttonNum * 10 + combatpresetNum}`; // Retrieve all presets from local storage, or initialize a new object if none exist let allPresets = JSON.parse(localStorage.getItem(COMBAT_PRESETS_KEY)) || {}; // Save current equipment settings into the relevant key of the allPresets object allPresets[presetName] = [ getVar(`preset_head_${combatpresetNum}`, null, "string"), getVar(`preset_body_${combatpresetNum}`, null, "string"), getVar(`preset_legs_${combatpresetNum}`, null, "string"), getVar(`preset_boots_${combatpresetNum}`, null, "string"), getVar(`preset_gloves_${combatpresetNum}`, null, "string"), getVar(`preset_amulet_${combatpresetNum}`, null, "string"), getVar(`preset_weapon_${combatpresetNum}`, null, "string"), getVar(`preset_shield_${combatpresetNum}`, null, "string"), getVar(`preset_arrows_${combatpresetNum}`, null, "string"), ]; // Update the single entry in local storage with the modified allPresets object localStorage.setItem(COMBAT_PRESETS_KEY, JSON.stringify(allPresets)); } sCCombat().saveLinkedPresetNum(buttonNum); }, saveCurrentPresets: function (buttonNum) { IdlePixelPlus.sendMessage(`PRESET_SAVE=${buttonNum}`) // Get linked preset numbers const LinkedPresetNum = JSON.parse(localStorage.getItem(COMBAT_PRESETS_LINK_KEY)) || 0; if (LinkedPresetNum === 0 || LinkedPresetNum === 99) { return; } sCCombat().savePresetGroups(LinkedPresetNum); let presetName = `CombatPreset ${LinkedPresetNum * 10 + buttonNum}`; // Retrieve all presets from local storage, or initialize a new object if none exist let allPresets = JSON.parse(localStorage.getItem(COMBAT_PRESETS_KEY)) || {}; // Save current equipment settings into the relevant key of the allPresets object allPresets[presetName] = [ 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(COMBAT_PRESETS_KEY, JSON.stringify(allPresets)); }, saveLinkedPresetNum: function (buttonNum) { const LinkedPresetNum = JSON.parse(localStorage.getItem(COMBAT_PRESETS_LINK_KEY)) || 0; // Lock button on/off switching if (LinkedPresetNum === 99) { if (buttonNum === 99) { buttonNum = 0; } else { return; } } localStorage.setItem(COMBAT_PRESETS_LINK_KEY, buttonNum); sCCombat().removeHighlightPresetButtons(); sCCombat().highlightPresetButtons(); }, highlightPresetButtons: function () { // Retrieve the preset number from localStorage (default to 0 if not found) const LinkedPresetNum = JSON.parse(localStorage.getItem(COMBAT_PRESETS_LINK_KEY)) || 0; if (LinkedPresetNum >= 6 && LinkedPresetNum <= 10) { // For numbers between 6 and 10, apply a highlight to the corresponding group and icon const groupElem = document.getElementById("slapchop-quickpreset-buttons-groups"); if (groupElem) { groupElem.className = "current-group-" + LinkedPresetNum; } const iconElem = document.getElementById("in-combat-presets-icon-" + LinkedPresetNum); if (iconElem) { iconElem.classList.add("current"); } } else { const unlinkElem = document.getElementById("slapchop-quickpreset-buttons-unlink"); if (unlinkElem) { // If LinkedPresetNum is 0, apply highlight to the unlink button unlinkElem.className = "current-group-0"; } if (LinkedPresetNum === 99) { // If LinkedPresetNum is 99, apply highlight to the unlink-lock button const unlinkLockElem = document.getElementById("slapchop-quickpreset-buttons-unlink-lock"); if (unlinkLockElem) { unlinkLockElem.className = "current-group-99"; } } } }, removeHighlightPresetButtons: function () { // Remove highlight for the entire preset group container const groupElem = document.getElementById("slapchop-quickpreset-buttons-groups"); if (groupElem) { groupElem.className = ""; // Reset the container's class } // Remove highlights from preset icons for groups 6 to 10 for (let i = 6; i <= 10; i++) { const iconElem = document.getElementById("in-combat-presets-icon-" + i); if (iconElem) { iconElem.classList.remove("current"); } } // Remove highlights from the unlink and unlink-lock buttons const unlinkElem = document.getElementById("slapchop-quickpreset-buttons-unlink"); if (unlinkElem) { unlinkElem.className = ""; } const unlinkLockElem = document.getElementById("slapchop-quickpreset-buttons-unlink-lock"); if (unlinkLockElem) { unlinkLockElem.className = ""; } }, 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"> <div class="slapchop-quickpreset-buttons"> <h5>Quick Current Presets:</h5> <h5>Current Preset Groups: <button id="slapchop-quickpreset-buttons-unlink" onclick="sCCombat().saveLinkedPresetNum(0)">Unlink Current Gr</button> ≪ <button id="slapchop-quickpreset-buttons-unlink-lock" onclick="sCCombat().saveLinkedPresetNum(99)">Lock</button> </h5> <div> <div> <button onclick="sCCombat().saveCurrentPresets(1);">Save 1</button> <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=1~1')">Load 1</button> </div> <div> <button onclick="sCCombat().saveCurrentPresets(2);">Save 2</button> <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=2~1')">Load 2</button> </div> <div> <button onclick="sCCombat().saveCurrentPresets(3);">Save 3</button> <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=3~1')">Load 3</button> </div> <div> <button onclick="sCCombat().saveCurrentPresets(4);">Save 4</button> <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=4~1')">Load 4</button> </div> <div> <button onclick="sCCombat().saveCurrentPresets(5);">Save 5</button> <button onclick="IdlePixelPlus.sendMessage('PRESET_LOAD=5~1')">Load 5</button> </div> </div> <div id="slapchop-quickpreset-buttons-groups" class=""> <div class="slapchop-quickpreset-buttons-group6"> <button onclick="sCCombat().savePresetGroups(6)">Save Gr6</button> <button onclick="sCCombat().loadPresetGroups(6)">Load Gr6</button> </div> <div class="slapchop-quickpreset-buttons-group7"> <button onclick="sCCombat().savePresetGroups(7)">Save Gr7</button> <button onclick="sCCombat().loadPresetGroups(7)">Load Gr7</button> </div> <div class="slapchop-quickpreset-buttons-group8"> <button onclick="sCCombat().savePresetGroups(8)">Save Gr8</button> <button onclick="sCCombat().loadPresetGroups(8)">Load Gr8</button> </div> <div class="slapchop-quickpreset-buttons-group9"> <button onclick="sCCombat().savePresetGroups(9)">Save Gr9</button> <button onclick="sCCombat().loadPresetGroups(9)">Load Gr9</button> </div> <div class="slapchop-quickpreset-buttons-group10"> <button onclick="sCCombat().savePresetGroups(10)">Save Gr10</button> <button onclick="sCCombat().loadPresetGroups(10)">Load Gr10</button> </div> </div> </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 = `× ${fpPercent[0]} + ${fpPercent[1].replace( /^0/, "" )}%`; let fpPirateLabel = `× ${ fpPiratePercent[0] } + ${fpPiratePercent[1].replace(/^0/, "")}%`; let energyTrioLabel = `× ${ trioEnergyPercent[0] } + ${trioEnergyPercent[1].replace(/^0/, "")}%`; let energyLabel = `× ${ 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="Presets group 6" id="in-combat-presets-icon-6" onclick="sCCombat().loadPresetGroups(6)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" /> <img data-tooltip="Presets group 7" id="in-combat-presets-icon-7" onclick="sCCombat().loadPresetGroups(7)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" /> <img data-tooltip="Presets group 8" id="in-combat-presets-icon-8" onclick="sCCombat().loadPresetGroups(8)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" /> <img data-tooltip="Presets group 9" id="in-combat-presets-icon-9" onclick="sCCombat().loadPresetGroups(9)" class="combat-presets-combat-icon hover w30" src="${IMAGE_URL_BASE}/melee.png" /> <img data-tooltip="Presets group 10" id="in-combat-presets-icon-10" onclick="sCCombat().loadPresetGroups(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().loadPresetGroups(6), //key [6] 55: () => sCCombat().loadPresetGroups(7), //key [7] 56: () => sCCombat().loadPresetGroups(8), //key [8] 57: () => sCCombat().loadPresetGroups(9), //key [9] 48: () => sCCombat().loadPresetGroups(10), //key [0] 189: () => sCCombat().equipAllRings(), //key [-] 187: () => sCCombat().unEquipAllRings(), //key [=] }; 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().highlightPresetButtons(); 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); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址