Greasy Fork is available in English.

IdlePixel SlapChop - Woodcutting Code

Split off of IdlePixel Slapchop for all Woodcutting Code.

このスクリプトは単体で利用できません。右のようなメタデータを含むスクリプトから、ライブラリとして読み込まれます: // @require https://update.greasyfork.org/scripts/483555/1304279/IdlePixel%20SlapChop%20-%20Woodcutting%20Code.js

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください。
// ==UserScript==
// @name         IdlePixel SlapChop - Woodcutting Code
// @namespace    godofnades.idlepixel
// @version      0.1
// @description  Split off of IdlePixel Slapchop for all Woodcutting Code.
// @author       GodofNades
// @license      MIT
// @match        *://idle-pixel.com/login/play/
// @grant        none
// ==/UserScript==

(function () {
	"use strict";

	let singleOverride;

	const IMAGE_URL_BASE = document
		.querySelector("itembox[data-item=copper] img")
		.src.replace(/\/[^/]+.png$/, "");

	const LOGS = Object.keys(Cooking.LOG_HEAT_MAP);

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

	function initQuickBurn() {
		LOGS.forEach((item) => {
			$(`itembox[data-item="${item}"]`).on("contextmenu", (event) => {
				if (IdlePixelPlus.plugins.slapchop.getConfig("quickBurnRightClickEnabled")) {
					const primary = window.isPrimaryActionSlapchop(event);
					const alt = window.isAltActionSlapchop(event);
					if (primary || alt) {
						window.quickBurn(item, !primary);
						event.stopPropagation();
						event.preventDefault();
						return false;
					}
				}
				return true;
			});
		});
	}

	function initQuickFoundry() {
		let html = `
        <div id="slapchop-quickfoundry" class="slapchop-quickfight">
          <h5>Quick Foundry:</h5>
          <div class="slapchop-quicksmelt-buttons">
        `;
		window.LOGS.forEach((log) => {
			if (log != "dense_logs") {
				html += `
              <button id="slapchop-quickfoundry-${log}" type="button" onclick="window.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>
        `;
		$("#panel-woodcutting hr").first().after(html);
	}

	function updateQuickFoundry() {
		const foundryBusy =
			IdlePixelPlus.getVarOrDefault("foundry_amount", 0, "int") != 0;
		LOGS.forEach((log) => {
			if (log != "dense_logs") {
				const max = window.maxFoundry(log);
				$(`[data-slap="max-foundry-${log}"]`).text(max);
				if (!foundryBusy && max > 0) {
					$(`#slapchop-quickfoundry-${log}`).prop("disabled", false);
				} else {
					$(`#slapchop-quickfoundry-${log}`).prop("disabled", true);
				}
			}
		});
	}

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

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

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

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

	function initQuickChop() {
		$("#panel-woodcutting itembox").first().before(`
        <itembox id="slapchop-lumberjack" class="shadow hover" data-item="slapchop_lumberjack" onclick="window.quickChop()">
            <div class="center mt-1"><img width="50" height="50" src=""></div>
            <div class="center mt-2">Chop</div>
        </itembox>
        `);
		$("#panel-woodcutting itembox").first().after(`
        <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="https://d1xsc8x7nc5q8t.cloudfront.net/images/rain_potion.png" title="rain_potion"></div>
            <div class="center mt-2">Chop</div>
        </itembox>
        `);
	}

	function quickChop() {
		for (let i = 1; i <= 5; i++) {
			let status = IdlePixelPlus.getVarOrDefault("tree_stage_" + i, 0, "int");
			let treeType = IdlePixelPlus.getVarOrDefault("tree_" + i, "none");
			let sdCut = IdlePixelPlus.plugins.slapchop.getConfig("quickChopSDTreesEnabled");
			let regCut = IdlePixelPlus.plugins.slapchop.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);
			}
		}
	}

	window.initQuickFoundry = initQuickFoundry;
	window.initQuickBurn = initQuickBurn;
	window.initQuickChop = initQuickChop;
	window.quickBurn = quickBurn;
	window.quickFoundry = quickFoundry;
	window.maxFoundry = maxFoundry;
	window.quickChop = quickChop;
	window.updateQuickFoundry = updateQuickFoundry;
	window.LOGS = LOGS;
})();