Greasy Fork is available in English.

Melvor Completion Log Helper

Shows time remaining for completing a task with your current resources. Takes into account Mastery Levels and other bonuses.

2020-07-03 या दिनांकाला. सर्वात नवीन आवृत्ती पाहा.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

// ==UserScript==
// @name         Melvor Completion Log Helper
// @namespace    http://tampermonkey.net/
// @version      0.1.2
// @description  Shows time remaining for completing a task with your current resources. Takes into account Mastery Levels and other bonuses.
// @author       Breindahl#2660
// @match        https://*.melvoridle.com/*
// @grant        none
// ==/UserScript==
/* jshint esversion: 6 */

// Made for version 0.15.4

(main => {
    var script = document.createElement('script');
    script.textContent = `try {(${main})();} catch (e) {console.log(e);}`;
    document.body.appendChild(script).parentNode.removeChild(script);
})(() => {

// Loading script
console.log('Melvor Completion Log Helper Loaded');


function openItemLogExtra() {
	console.log('openItemLog');
    let timesFound = (timesSold = gpFromSale = deathCount = damageTaken = damageDealt = missedAttacks = timesEaten = healedFor = totalAttacks = amountUsedInCombat = timeWaited = timesDied = timesGrown = harvestAmount = enemiesKilled = timesOpened = '');
    $('#itemlog-container').html('');
    for (let i = 0; i < itemStats.length; i++) {
        if (itemStats[i].timesFound > 0) {
            timesFound = timesSold = gpFromSale = deathCount = damageTaken = damageDealt = missedAttacks = timesEaten = healedFor = totalAttacks = amountUsedInCombat = timeWaited = timesDied = timesGrown = harvestAmount = enemiesKilled = timesOpened = '';
            if (itemStats[i].timesFound > 0) timesFound = "<br>Times Found: <small class='text-warning'>" + formatNumber(itemStats[i].timesFound) + '</small>';
            if (itemStats[i].timesSold > 0) timesSold = "<br>Quantity Sold: <small class='text-warning'>" + formatNumber(itemStats[i].timesSold) + '</small>';
            if (itemStats[i].gpFromSale > 0) gpFromSale = "<br>GP Gained from sales: <small class='text-warning'>" + formatNumber(itemStats[i].gpFromSale) + '</small>';
            if (itemStats[i].deathCount > 0) deathCount = "<br>Times lost due to death: <small class='text-warning'>" + formatNumber(itemStats[i].deathCount) + '</small>';
            if (itemStats[i].damageTaken > 0) damageTaken = "<br>Damage Taken whilst Equipped: <small class='text-warning'>" + formatNumber(itemStats[i].damageTaken) + '</small>';
            if (itemStats[i].damageDealt > 0) damageDealt = "<br>Damage Dealt: <small class='text-warning'>" + formatNumber(itemStats[i].damageDealt) + '</small>';
            if (itemStats[i].missedAttacks > 0) missedAttacks = "<br>Attacks Missed: <small class='text-warning'>" + formatNumber(itemStats[i].missedAttacks) + '</small>';
            if (itemStats[i].timesEaten > 0) timesEaten = "<br>Times Eaten: <small class='text-warning'>" + formatNumber(itemStats[i].timesEaten) + '</small>';
            if (itemStats[i].healedFor > 0) healedFor = "<br>Healed for: <small class='text-warning'>" + formatNumber(itemStats[i].healedFor) + '</small>';
            if (itemStats[i].totalAttacks > 0) totalAttacks = "<br>Total Attacks: <small class='text-warning'>" + formatNumber(itemStats[i].totalAttacks) + '</small>';
            if (itemStats[i].amountUsedInCombat > 0) amountUsedInCombat = "<br>Amount used in combat: <small class='text-warning'>" + formatNumber(itemStats[i].amountUsedInCombat) + '</small>';
            if (itemStats[i].timeWaited > 0) timeWaited = "<br>Time spent waiting to grow: <small class='text-warning'>" + formatNumber(itemStats[i].timeWaited) + '</small>';
            if (itemStats[i].timesDied > 0) timesDied = "<br>Crop deaths: <small class='text-warning'>" + formatNumber(itemStats[i].timesDied) + '</small>';
            if (itemStats[i].timesGrown > 0) timesGrown = "<br>Successful grows: <small class='text-warning'>" + formatNumber(itemStats[i].timesGrown) + '</small>';
            if (itemStats[i].harvestAmount > 0) harvestAmount = "<br>Amount harvested: <small class='text-warning'>" + formatNumber(itemStats[i].harvestAmount) + '</small>';
            if (itemStats[i].enemiesKilled > 0) enemiesKilled = "<br>Enemies killed: <small class='text-warning'>" + formatNumber(itemStats[i].enemiesKilled) + '</small>';
            if (itemStats[i].timesOpened > 0) timesOpened = "<br>Opened: <small class='text-warning'>" + formatNumber(itemStats[i].timesOpened) + '</small>';
            $('#itemlog-container').append('<img class="skill-icon-sm js-tooltip-enable" src="' + items[i].media + '" data-toggle="tooltip" data-html="true" data-placement="bottom" title="" data-original-title="' + items[i].name + "<small class='text-info'> " + timesFound + timesSold + gpFromSale + totalAttacks + missedAttacks + damageDealt + damageTaken + enemiesKilled + amountUsedInCombat + timesEaten + healedFor + timesGrown + timesDied + timeWaited + harvestAmount + timesOpened + '</small>">');
        } else {
            $('#itemlog-container').append('<a href="https://wiki.melvoridle.com/index.php?title=' + items[i].name + '" target="blank"><img class="skill-icon-sm js-tooltip-enable" style="opacity:0.3;filter: grayscale(50%);" src="' + items[i].media + '" data-toggle="tooltip" data-html="true" data-placement="bottom" title="" data-original-title="' + items[i].name + '">');
        }
    }
    updateTooltips();
    $('#modal-item-log').modal('show');
}

function openMonsterLogExtra() {
    let damageDealtToPlayer = (damageTakenFromPlayer = killedByPlayer = killedPlayer = hitsToPlayer = hitsFromPlayer = enemyMissed = playerMissed = seen = ranAway = '');
    $('#monsterlog-container').html('');
    for (let i = 0; i < monsterStats.length; i++) {
        if (monsterStats[i].killedByPlayer > 0) {
            damageDealtToPlayer = damageTakenFromPlayer = killedByPlayer = killedPlayer = hitsToPlayer = hitsFromPlayer = enemyMissed = playerMissed = seen = ranAway = '';
            damageTakenFromPlayer = "<br>Total Damage Dealt to Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].damageTakenFromPlayer) + '</small>';
            damageDealtToPlayer = "<br>Total Damage Taken from Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].damageDealtToPlayer) + '</small>';
            killedByPlayer = "<br>Times Slain: <small class='text-warning'>" + formatNumber(monsterStats[i].killedByPlayer) + '</small>';
            killedPlayer = "<br>Times Killed by Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].killedPlayer) + '</small>';
            hitsToPlayer = "<br>Successful hits by Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].hitsToPlayer) + '</small>';
            hitsFromPlayer = "<br>Successful hits to Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].hitsFromPlayer) + '</small>';
            enemyMissed = "<br>Missed Attacks by Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].enemyMissed) + '</small>';
            playerMissed = "<br>Missed Attacks to Monster: <small class='text-warning'>" + formatNumber(monsterStats[i].playerMissed) + '</small>';
            seen = "<br>Times Fought: <small class='text-warning'>" + formatNumber(monsterStats[i].seen) + '</small>';
            ranAway = "<br>Times Ran Away: <small class='text-warning'>" + formatNumber(monsterStats[i].ranAway) + '</small>';
            $('#monsterlog-container').append('<img class="skill-icon-md js-tooltip-enable" src="' + MONSTERS[i].media + '" data-toggle="tooltip" data-html="true" data-placement="bottom" title="" data-original-title="' + MONSTERS[i].name + "<small class='text-info'> " + seen + killedByPlayer + killedPlayer + damageTakenFromPlayer + damageDealtToPlayer + hitsFromPlayer + hitsToPlayer + playerMissed + enemyMissed + ranAway + '</small>">');
        } else {
            $('#monsterlog-container').append('<a href="https://wiki.melvoridle.com/index.php?title=' + MONSTERS[i].name + '" target="blank"><img class="skill-icon-md js-tooltip-enable" style="opacity:0.3;filter: grayscale(50%);" src="' + MONSTERS[i].media + '" data-toggle="tooltip" data-html="true" data-placement="bottom" title="" data-original-title="' + MONSTERS[i].name + '"></a>');
        }
    }
    updateTooltips();
    $('#modal-monster-log').modal('show');
}

function showMasteryProgressExtra(skill, masteryArray) {
    $('#modal-content-mastery').html('');
    let masteryHtml = '';
    masteryHtml += '<div class="block block-rounded block-link-pop border-top border-' + setToLowercase(skillName[skill]) + ' border-4x">';
    masteryHtml += '<div class="block-header">';
    masteryHtml += '<h3 class="block-title"><img class="mastery-icon-xs mr-2" src="assets/media/main/mastery_header.svg">' + skillName[skill] + '</h3>';
    masteryHtml += '<div class="block-options"><button type="button" class="btn-block-option" data-dismiss="modal" aria-label="Close"><i class="fa fa-fw fa-times"></i></button></div>';
    masteryHtml += '</div>';
    masteryHtml += '<div class="row"><div class="col-12"><div class="block-content">';
    masteryHtml += '<table class="table table-sm table-vcenter">';
    masteryHtml += '<thead><tr><th class="text-center" style="width: 65px;">Item</th><th class="text-center" style="width: 65px;">Level</th><th>Progress</th></tr></thead><tbody>';
    let currentLevelXP;
    let nextLevelXP;
    let nextMasteryProgress;
    if (skill === CONSTANTS.skill.Smithing) {
        for (let i = 0; i < smithingSorted.length; i++) {
            masteryHtml += '<tr>';
            masteryHtml += '<th class="text-center" scope="row">';
            if (masteryArray[smithingSorted[i].smithingID].masteryXP < 1) {
                let media = getMasteryMedia(i, skill);
                masteryHtml += '<img class="milestone-icon" style="opacity:0.3;filter: grayscale(50%);" src="' + media + '">';
            } else {
                let media = getMasteryMedia(i, skill);
                masteryHtml += '<img class="milestone-icon" src="' + media + '">';
            }
            masteryHtml += '</th>';
            masteryHtml += '<th class="text-center" scope="row">';
            masteryHtml += masteryArray[smithingSorted[i].smithingID].mastery;
            masteryHtml += '</th>';
            masteryHtml += '<td class="font-w600 font-size-sm">';
            masteryHtml += '<div class="progress active" style="height: 10px">';
            currentLevelXP = masteryExp.level_to_xp(masteryArray[smithingSorted[i].smithingID].mastery);
            nextLevelXP = masteryExp.level_to_xp(masteryArray[smithingSorted[i].smithingID].mastery + 1);
            //Figure out next level progress percentage
            nextMasteryProgress = (masteryArray[smithingSorted[i].smithingID].masteryXP - currentLevelXP) / (nextLevelXP - currentLevelXP) * 100;
            masteryHtml += '<div class="progress-bar bg-info" role="progressbar" style="width: ' + nextMasteryProgress + '%;" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">';
            masteryHtml += '</div></div></td></tr>';
        }
    } else {
        for (let i = 0; i < masteryArray.length; i++) {
            masteryHtml += '<tr>';
            masteryHtml += '<th class="text-center" scope="row">';
            if (masteryArray[i].masteryXP < 1) {
                let media = getMasteryMedia(i, skill);
                masteryHtml += '<img class="milestone-icon" style="opacity:0.3;filter: grayscale(50%);" src="' + media + '">';
            } else {
                let media = getMasteryMedia(i, skill);
                masteryHtml += '<img class="milestone-icon" src="' + media + '">';
            }
            masteryHtml += '</th>';
            if (masteryArray[i].mastery < 99) masteryHtml += '<th class="text-center" scope="row">';
            else masteryHtml += '<th class="text-center text-complete" scope="row">';
            if (masteryArray[i].mastery > 99) masteryHtml += '99';
            else masteryHtml += masteryArray[i].mastery;
            masteryHtml += '</th>';
            masteryHtml += '<td class="font-w600 font-size-sm">';
            masteryHtml += '<div class="progress active" style="height: 10px">';
            currentLevelXP = masteryExp.level_to_xp(masteryArray[i].mastery);
            nextLevelXP = masteryExp.level_to_xp(masteryArray[i].mastery + 1);
            if (masteryArray[i].mastery < 99) {
                nextMasteryProgress = (masteryArray[i].masteryXP - currentLevelXP) / (nextLevelXP - currentLevelXP) * 100;
                masteryHtml += '<div class="progress-bar bg-info" role="progressbar" style="width: ' + nextMasteryProgress + '%;" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">';
            } else {
                nextMasteryProgress = 100;
                masteryHtml += '<div class="progress-bar bg-success" role="progressbar" style="width: ' + nextMasteryProgress + '%;" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">';
            }
            masteryHtml += '</div></div></td></tr>';
        }
    }
    masteryHtml += '</tbody></table></div></div></div></div>';
    $('#modal-content-mastery').append(masteryHtml);
    $('#modal-mastery').modal('show');
}

window.openItemLog = function() {
	openItemLogExtra();
};

window.openMonsterLog = function() {
	openMonsterLogExtra();
};

window.showMasteryProgress = function(...args) {
	showMasteryProgressExtra(...args);
};

});