您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Provides some general additions to Elethor
当前为
// ==UserScript== // @name Elethor General Purpose // @description Provides some general additions to Elethor // @namespace https://www.elethor.com/ // @version 1.0.14 // @author Anders Morgan Larsen (Xortrox) // @match https://elethor.com/* // @match https://www.elethor.com/* // @run-at document-start // @grant none // ==/UserScript== (function() { const currentUserData = {}; const moduleName = 'Elethor General Purpose'; const version = '1.0.14' const playerHealthBarElementDefinition = '.progress.is-medium.is-danger'; const playerHealthBarTextElementDefinition = '.is-fight-health'; function getBattleHealthPercentage() { const playerHealth = document.querySelector(playerHealthBarElementDefinition); if (!playerHealth) { return 0; } return playerHealth.value / playerHealth.max * 100; } function initializeUpdateBattleHealthPercentage() { if (window.elethorExtrasInterval) { clearInterval(window.elethorExtrasInterval); } window.elethorExtrasInterval = setInterval(() => { const playerHealthText = document.querySelector(playerHealthBarTextElementDefinition); const healthPercentage = getBattleHealthPercentage(); if (playerHealthText && healthPercentage && !isNaN(healthPercentage)) { let percentageDisplay; if (playerHealthText.children.length === 0) { percentageDisplay = document.createElement('span'); playerHealthText.appendChild(percentageDisplay); } else { percentageDisplay = playerHealthText.children[0]; } if (percentageDisplay) { percentageDisplay.innerText = ` (${healthPercentage.toFixed(3)}%)`; } } }, 500); console.log(`[${moduleName} v${version}] Battle Percentage initialized.`); } function initializeToastKiller() { document.addEventListener('click', function(e) { if (e.target && e.target.className && e.target.className.includes && e.target.className.includes('toasted') ) { e.target.remove(); } }); console.log(`[${moduleName} v${version}] Toast Killer initialized.`); } function initializeXHRHook() { let rawSend = XMLHttpRequest.prototype.send; XMLHttpRequest.prototype.send = function() { if (!this._hooked) { this._hooked = true; this.addEventListener('readystatechange', function() { if (this.readyState === XMLHttpRequest.DONE) { setupHook(this); } }, false); } rawSend.apply(this, arguments); } function setupHook(xhr) { if (window.elethorGeneralPurposeOnUserLoad) { const e = new Event('EGPXHR'); e.xhr = xhr; window.elethorGeneralPurposeOnUserLoad.dispatchEvent(e); } } window.elethorGeneralPurposeOnUserLoad = new EventTarget(); console.log(`[${moduleName} v${version}] XHR Hook initialized.`); } function initializeUserLoadListener() { elethorGeneralPurposeOnUserLoad.addEventListener('EGPXHR', function (e) { if (e && e.xhr && e.xhr.responseURL && e.xhr.responseURL.endsWith && e.xhr.responseURL.endsWith('/game/user') ) { try { const userData = JSON.parse(e.xhr.responseText); console.log(`[${moduleName} v${version}] User Data hook:`, userData); if (userData) { for (const key of Object.keys(userData)) { currentUserData[key] = userData[key]; } console.log(`[${moduleName} v${version}] User Data loaded:`, currentUserData); } } catch (e) { console.log(`[${moduleName} v${version}] Error parsing userData:`, e); } } }); console.log(`[${moduleName} v${version}] User Load Listener initialized.`); } function initializeInventoryStatsLoadListener() { elethorGeneralPurposeOnUserLoad.addEventListener('EGPXHR', function (e) { if (e && e.xhr && e.xhr.responseURL && e.xhr.responseURL.endsWith && e.xhr.responseURL.endsWith('/game/inventory/stats') ) { setTimeout(() => { updateEquipmentPercentageSummary(); setTimeout(updateInventoryStatsPercentages, 1000); }); } }); console.log(`[${moduleName} v${version}] User Load Listener initialized.`); } function updateEquipmentPercentageSummary() { document.querySelector('.is-equipment>div>div').setAttribute('style', 'width: 50%') let percentagesTable = document.querySelector('#egpPercentagesSummary') if (!percentagesTable){ percentagesTable = document.querySelector('.is-equipment>div>div:nth-child(2)').cloneNode(true); percentagesTable.setAttribute('style', 'width: 25%'); percentagesTable.id='egpPercentagesSummary'; document.querySelector('.is-equipment>div').appendChild(percentagesTable); for (const child of percentagesTable.children[0].children) { child.children[0].remove(); } document.querySelector('#egpPercentagesSummary>table>tr:nth-child(8)').setAttribute('style', 'height:43px'); } } function getStatSummary(equipment) { const summary = { base: {}, energizements: {} }; if (equipment) { for (const key of Object.keys(equipment)) { const item = equipment[key]; /** * Sums base attributes by name * */ if (item && item.attributes) { for (const attributeName of Object.keys(item.attributes)) { const attributeValue = item.attributes[attributeName]; if (!summary.base[attributeName]) { summary.base[attributeName] = 0; } summary.base[attributeName] += attributeValue; } } /** * Sums energizements by stat name * */ if (item && item.upgrade && item.upgrade.energizements) { for (const energizement of item.upgrade.energizements) { if (!summary.energizements[energizement.stat]) { summary.energizements[energizement.stat] = 0; } summary.energizements[energizement.stat] += Number(energizement.boost); } } } } return summary; } function updateInventoryStatsPercentages() { let percentagesTable = document.querySelector('#egpPercentagesSummary') if (percentagesTable && currentUserData && currentUserData.equipment){ const statSummary = getStatSummary(currentUserData.equipment); console.log('statSummary:', statSummary); const baseKeys = Object.keys(statSummary.base); const energizementKeys = Object.keys(statSummary.energizements); let allKeys = baseKeys.concat(energizementKeys); const filterUniques = {}; for (const key of allKeys){ filterUniques[key] = true; } allKeys = Object.keys(filterUniques); allKeys.sort(); const tableRows = percentagesTable.children[0].children; let rowIndex = 0; for (const key of allKeys) { const row = tableRows[rowIndex]; const rowText = row.children[0].children[0]; const rowBase = statSummary.base[key] || 0; const rowEnergizement = (statSummary.energizements[key] || 0) * 100; if (key.startsWith('+')) { rowText.innerText = `${key}: ${rowBase} x (level/10)`; } else { rowText.innerText = `${key}: ${rowBase} (${rowEnergizement.toFixed(0)}%)`; } rowIndex++; } } } (function run() { initializeUpdateBattleHealthPercentage(); initializeToastKiller(); initializeXHRHook(); initializeUserLoadListener(); initializeInventoryStatsLoadListener(); console.log(`[${moduleName} v${version}] Loaded.`); })(); })();