Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- // ==UserScript==
- // @name IdlePixel Slap Chop - GodofNades Fork
- // @namespace com.anwinity.idlepixel
- // @version 3.0.11
- // @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
- // @downloadURL https://update.greasyfork.org/scripts/459139/IdlePixel%20Slap%20Chop%20-%20GodofNades%20Fork.user.js
- // @updateURL https://update.greasyfork.org/scripts/459139/IdlePixel%20Slap%20Chop%20-%20GodofNades%20Fork.meta.js
- // ==/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 itemBox = document.querySelector(`[data-item="${item}"]`);
- 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,
- },
- },
- };
- 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>
- </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.querySelector("#panel-combat .panel-logo-xp-area");
- if (panelCombat) {
- panelCombat.insertAdjacentHTML("afterend", html);
- }
- const gamePanelsCombatItemsArea = document.querySelector(
- "#game-panels-combat-items-area .itembox-fight"
- );
- 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");
- Object.values(IdlePixelPlus.info.combatZones).forEach((zone) => {
- let disabled = fp < zone.fightPointCost || energy < zone.energyCost;
- let disabledPirate = fp < 2000 || evilPirate == 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 fpLabel = `× ${fpPercent[0]} + ${fpPercent[1].replace(
- /^0/,
- ""
- )}%`;
- let fpPirateLabel = `× ${
- fpPiratePercent[0]
- } + ${fpPiratePercent[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 buttonPirate = document.querySelector(
- `#slapchop-quickfight-pirate button`
- );
- buttonPirate.disabled = disabledPirate;
- fpProgress.style.width = `${fpPercent}%`;
- fpProgressPirate.style.width = `${fpPiratePercent}%`;
- energyProgress.style.width = `${energyPercent}%`;
- fpProgressValue.innerHTML = fpLabel;
- fpPirateProgressValue.innerHTML = fpPirateLabel;
- energyProgressValue.innerHTML = energyLabel;
- energyPirateProgressValue.innerHTML = `${evilPirate} Remaining`;
- });
- },
- 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",
- ].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-ready"
- );
- 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);
- })();
Add Comment
Please, Sign In to add comment