// ==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 = `× ${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="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);
})();