您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Automatically selects professions for empty slots
// ==UserScript== // @name Neverwinter gateway - Professions Robot // @description Automatically selects professions for empty slots // @namespace https://greasyfork.org/scripts/9812-neverwinter-gateway-professions-robot/ // @include http://gateway*.playneverwinter.com/* // @include https://gateway*.playneverwinter.com/* // @include http://gateway.*.perfectworld.eu/* // @include https://gateway.*.perfectworld.eu/* // @require https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.2/jquery-ui.min.js // @resource jqUI_CSS https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.2/themes/cupertino/jquery-ui.css // @originalAuthor Mustex/Bunta // @modifiedBy NW gateway Professions Bot Developers & Contributors // @version 4.9.7 // @license http://creativecommons.org/licenses/by-nc-sa/3.0/us/ // @grant GM_getValue // @grant GM_setValue // @grant GM_listValues // @grant GM_deleteValue // @grant GM_addStyle // @grant GM_getResourceText // ==/UserScript== /* Developers & Contributors - BigRedBot - Bluep - dlebedynskyi - Frankescript - Kakoura - mac-nw - Nametaken - noonereally - Numberb - Phr33d0m - Rotten_mind - WloBeb RELEASE NOTES: https://github.com/Phr33d0m/NW-Profession-Bot/blob/master/CHANGELOG.md */ // Make sure it's running on the main page, no frames var scriptVersion = 4.9; var forceResetOnVerBelow = 4.7; var forceSettingsResetOnUpgrade = true; var microVersion = GM_info.script.version; if(window.self !== window.top) { throw ""; } var current_Gateway = _select_Gateway(); // Set global console variables var fouxConsole = { log: function() {}, info: function() {}, error: function() {}, warn: function() {} }; var console = unsafeWindow.console || fouxConsole; var chardiamonds = []; var zaxdiamonds = 0; var chargold = []; var definedTask = {}; var translation = {}; var failedTasksList = []; var failedProfiles = {}; var collectTaskAttempts = new Array(9); var k = 9; while (k) {collectTaskAttempts[--k] = 0}; //collectTaskAttempts.fill(0); js6 var antiInfLoopTrap = {// without this script sometimes try to start the same task in infinite loop (lags?) prevCharName: "unknown", // character name which recently launched a task prevTaskName: "unknown", // name of the task previously launched startCounter: 0, // how many times the same character starts the same task currCharName: "unknown", // character name which try to launch new task currTaskName: "unknown", // name of the new task to launch trapActivation: 15 // number of repetition to activation trap }; var pleaseBuy = []; // No Leadership in Gateway stuff var leadershipSlots = {}; // Page Reloading function // Every second the page is idle or loading is tracked var loading_reset = false; // Enables a periodic reload if this is toggled on by the Auto Reload check box on the settings panel var s_paused = false; // extend the paused setting to the Page Reloading function // Include JqueryUI CSS var jqUI_CssSrc = GM_getResourceText("jqUI_CSS"); /*jqUI_CssSrc = jqUI_CssSrc.replace (/url\(images\//g, "url(https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.2/themes/dark-hive/images/");*/ jqUI_CssSrc = jqUI_CssSrc.replace(/url\(images\//g, "url(https://ajax.googleapis.com/ajax/libs/jqueryui/1.10.3/themes/cupertino/images/"); jqUI_CssSrc = jqUI_CssSrc.replace(/font-size: 1\.1em/g, "font-size: 0.9em"); GM_addStyle(jqUI_CssSrc); function _select_Gateway() { // Check for Gateway used to if(window.location.href.indexOf("gatewaytest") > -1) { // detect gatewaytest Url console.log("GatewayTEST detected"); return "http://gatewaytest.playneverwinter.com"; } else if(window.location.href.indexOf("nw.ru.perfectworld") > -1) { console.log("GatewayRU detected"); return "http://gateway.nw.ru.perfectworld.eu"; } else { // must go somewhere console.log("Gateway detected"); return "http://gateway.playneverwinter.com"; } } (function() { var $ = unsafeWindow.$; //MAC-NW $.fn.waitUntilExists = function(handler, shouldRunHandlerOnce, isChild) { var found = 'found'; var $this = $(this.selector); var $elements = $this.not(function() { return $(this).data(found); }).each(handler).data(found, true); if (!isChild) { (window.waitUntilExists_Intervals = window.waitUntilExists_Intervals || {})[this.selector] = window.setInterval(function() { $this.waitUntilExists(handler, shouldRunHandlerOnce, true); }, 500); } else if (shouldRunHandlerOnce && $elements.length) { window.clearInterval(window.waitUntilExists_Intervals[this.selector]); } return $this; } // MAC-NW - Wait for tooltip to come up so we can alter the list $('.tooltip-menu button').waitUntilExists(function() { // Tooltip has open menu itemtooltip if ($('button.tooltip-menu button[data-url-silent^="/inventory/item-open"]') && !$('.tooltip-menu div.tooltip-openall').length && !$('.tooltip-menu button[data-url-silent^="/inventory/item-open"]').hasClass('disabled')) try { var thisItem = eval("client.dataModel.model." + $('.tooltip-menu button[data-url-silent^="/inventory/item-open"]').attr('data-url-silent').split("=")[1]); if (thisItem.count > 1) { if (thisItem.count >= 99) thisItem.count = 99; var openAllClick = "for (i = 1; i <= " + thisItem.count + "; i++){ window.setTimeout(function () {client.sendCommand('GatewayInventory_OpenRewardPack', '" + thisItem.uid + "');}, 500); }"; $('div.tooltip-menu').append('<div class="input-field button menu tooltip-openall"><div class="input-bg-left"></div><div class="input-bg-mid"></div><div class="input-bg-right"></div>\ <button class=" " onclick="' + openAllClick + '">Open All (' + thisItem.count + ')</button></div>'); //$('a.nav-dungeons').trigger('click'); window.setTimeout(function(){ $('a.nav-inventory').trigger('click'); },2000); } } catch (e) { console.log("ERROR: Did not succeed to add open all tooltip."); } }); $('.vendor-quantity-block span.attention').waitUntilExists(function() { if ($('.vendor-quantity-block span.attention span').length) $('.vendor-quantity-block span.attention').replaceWith('<div class="input-field button"><div class="input-bg-left"></div><div class="input-bg-mid"></div><div class="input-bg-right"></div><button onclick="$(\'.modal-confirm input\').val(\'' + $(".vendor-quantity-block span.attention span").text() + '\');">All (' + $(".vendor-quantity-block span.attention span").text() + ')</button></div>'); }); $('div.notification div.messages li').waitUntilExists(function() { if ($("div.notification div.messages li").length > 2) $("div.notification div.messages li").eq(0).remove(); }); // Always disable SCA tutorial if its active $('#help-dimmer.help-cont.whenTutorialActive').waitUntilExists(function() { client.toggleHelp(); }); //MAC-NW var state_loading = 0; // If "Page Loading" takes longer than 30 seconds, reload page (maybe a javascript error) var state_loading_time = 30; // default of 30 seconds var state_idle = 0; // If the page is idle for longer than 60 seconds, reload page (maybe a javascript error) var state_idle_time = 120; // default of 120 seconds var reload_hours = [2, 5, 8, 11, 14, 17, 20, 23]; // logout and reload every three hours - 2:29 - 5:29 - 8:29 - 11:29 - 14:29 - 17:29 - 20:29 - 23:29 var last_location = ""; // variable to track reference to page URL var reload_timer = setInterval(function() { if (!s_paused) { if (antiInfLoopTrap.startCounter >= antiInfLoopTrap.trapActivation) { unsafeWindow.location.href = current_Gateway; return; } if (loading_reset) { var loading_date = new Date(); var loading_sec = Number(loading_date.getSeconds()); var loading_min = Number(loading_date.getMinutes()); var loading_hour = Number(loading_date.getHours()); if (reload_hours.indexOf(loading_hour) >= 0 && loading_min == 29 && loading_sec < 2) { console.log("Auto Reload"); unsafeWindow.location.href = current_Gateway; return; } } // check for errors if ($("title").text().match(/Error/) || $("div.modal-content h3").text().match(/Disconnected/)) { console.log("Error detected - relogging"); unsafeWindow.location.href = current_Gateway; return; } if ($("div.loading-image:visible").length) { last_location = location.href; state_idle = 0; if (state_loading >= state_loading_time) { console.log("Page Loading too long"); state_loading = 0; location.reload(); } else { state_loading++; console.log("Page Loading ...", state_loading + "s"); } } // TODO: Add check for gateway disconnected //<div class="modal-content" id="modal_content"><h3>Disconnected from Gateway</h3><p>You have been disconnected.</p><button type="button" class="modal-button" onclick="window.location.reload(true);">Close</button> /* Can't use idle check with dataModel methods else if (location.href == last_location) { state_loading = 0; if (state_idle >= state_idle_time) { console.log("Page Idle too long"); state_idle = 0; unsafeWindow.location.href = current_Gateway ; // edited by RottenMind } else { state_idle++; // comment out to avoid console spam // console.log("Page Idle ...", state_idle + "s"); } } */ else { last_location = location.href; state_loading = 0; state_idle = 0; } } }, 1000); })(); (function() { addTranslation(); /** * Add a string of CSS to the main page * * @param {String} cssString The CSS to add to the main page */ function AddCss(cssString) { var head = document.getElementsByTagName('head')[0]; if (!head) return; var newCss = document.createElement('style'); newCss.type = "text/css"; newCss.innerHTML = cssString; head.appendChild(newCss); } function countLeadingSpaces(str) { return str.match(/^(\s*)/)[1].length; } // Setup global closure variables var $ = unsafeWindow.jQuery; var timerHandle = 0; var dfdNextRun = $.Deferred(); var curCharNum = 0; // current character counter var lastCharNum = curCharNum; var curCharName = ''; var curCharFullName = ''; var chartimers = {}; var maxLevel = 25; var waitingNextChar = false; var delay = { SHORT: 1000, MEDIUM: 5000, LONG: 30000, MINS: 300000, DEFAULT: 10000, // default delay TIMEOUT: 60000, // delay for cycle processing timeout }; var lastDailyResetTime = null; // Forcing settings clear ! var ver = parseFloat(GM_getValue("script_version", 0)); if ((ver < forceResetOnVerBelow) && forceSettingsResetOnUpgrade) { var str = "Detected an upgrade from old version or fresh install.<br />Proceeding will wipe all saved settings.<br />Please set characters to active after log in."; $('<div id="dialog-confirm" title="Setting wipe confirm">' + str + '</div>').dialog({ resizable: true, width: 500, modal: false, buttons: { "Continue": function() { $( this ).dialog( "close" ); window.setTimeout(function() { var keys = GM_listValues(); for (i = 0; i < keys.length; i++) { var key = keys[i]; GM_deleteValue(key); } GM_setValue("script_version", scriptVersion); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 50); }, 0); }, Cancel: function() { $( this ).dialog( "close" ); } } }); return; } function addProfile(profession, profile, base){ maxLevel = maxLevel || 25; definedTask = definedTask || {}; // general prototype for profession var professionBase = { taskListName: typeof(profession) ==='string' ? profession : profession.taskListName, // Friendly name used at the UI taskName: typeof(profession) ==='string' ? profession : profession.taskName, // String used at the gateway taskDefaultPriority: 2, // Priority to allocate free task slots: 0 - High, 1 - Medium, 2 - Low taskActive: true, taskDefaultSlotNum: 0, taskDescription: "", profiles: [] }; // creating new profession or using existing one var professionSet = (typeof profession === 'object') ? jQuery.extend(true, professionBase, profession) : definedTask[profession] || professionBase; if(!professionSet) {return;} if(!definedTask[profession]) {definedTask[profession] = professionSet;} if(!profile) {return;} // profile prototype var profileBase = { profileName: 'Add profile name', isProfileActive: true, level: {} }; // getting new profile formated var newProfile = jQuery.extend(true, profileBase, profile), baseProfile; // getting base to extend base = base || (professionSet.taskListName === 'Leadership' ? 'RP' : 'default'); if(base && typeof base === 'string') { var existing = professionSet.profiles.filter(function(e) {return e.profileName === base;}); if(existing && existing.length) {baseProfile = existing[0];} } // setting levels var baseLevels = baseProfile ? baseProfile.level : [], rec = 0; for(var i = 0; i <= maxLevel; i++) { // recur has priority if (rec > 0 ){ rec -=1; // setting empty array to handle later by fallback newProfile.level[i] = newProfile.level[i] || []; } if(newProfile.level && newProfile.level[i]){ // override for arrays if (Array.isArray(newProfile.level[i]) && newProfile.level[i].length){ // cancel rec since new array is defined rec = 0; // process array var ind = newProfile.level[i].indexOf('+'); if (ind>-1){ var def = newProfile.level[i].splice(0, ind); var tail = newProfile.level[i].splice(1, newProfile.level[i].length); def = def.concat(baseLevels[i] || [], tail || []); newProfile.level[i] = def; } } // process '+N' else if (typeof newProfile.level[i] == 'string' && newProfile.level[i][0] === '+'){ rec = parseInt(newProfile.level[i].replace(/\D/g,'')); rec = rec > 0 ? rec : 0; // setting empty array to handle later by fallback newProfile.level[i] = []; rec -=1; } } // falback to base if not defined else{ var baseLevel = baseLevels[i] || []; newProfile.level[i] = baseLevel; } // fallback from empty array to copy one before if (Array.isArray(newProfile.level[i]) && !newProfile.level[i].length && i> 0){ newProfile.level[i] = newProfile.level[i-1]; } } console.info("profile added ",newProfile.profileName, newProfile); professionSet.profiles.push(newProfile); } /* * Tasklist can be modified to configure the training you want to perform. * The configurable options window sets how many profession slots you want to use for each profession. * The level array below for each professions specifies the tasks you want to learn at each crafting level. * Each craft slot will pick the first task that meets requirements. * See http://pastebin.com/VaGntEha for Task Name Map. * Some names above do not match, use below code to check: * var tasks = client.dataModel.model.craftinglist['craft_' + profname].entries.filter(function(entry) { return entry.def && entry.def.displayname == taskname; }); tasks[0].def.name; */ definedTask["Leadership"] = { taskListName: "Leadership", // Friendly name used at the UI, have to be the same as key in definedTask array!!! taskName: "Leadership", // String used at the gateway taskDefaultPriority: 2, // Priority to allocate free task slots: 0 - High, 1 - Medium, 2 - Low taskActive: true, taskDefaultSlotNum: 9, taskDescription: "", profiles: [{ profileName: "RP", //profileDescription: "Does Resonance Stones, Thaumaturgic Stones and Artifact Stones.", isProfileActive: true, level: { 0: ["Leadership_Tier0_Intro_1"], 1: ["Leadership_Tier0_Intro_5", "Leadership_Tier0_Intro_4", "Leadership_Tier0_Intro_3", "Leadership_Tier0_Intro_2"], 2: ["Leadership_Tier1_Feedtheneedy", "Leadership_Tier1_2_Guardduty", "Leadership_Tier1_2_Training"], 3: ["Leadership_Tier1_Feedtheneedy", "Leadership_Tier1_2_Guardduty", "Leadership_Tier1_2_Training"], 4: ["Leadership_Tier1_Feedtheneedy", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty", "Leadership_Tier1_2_Training"], 5: ["Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 6: ["Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 7: ["Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 8: ["Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 9: ["Leadership_Tier1_5_Explore", "Leadership_Tier2_9_Chart", "Leadership_Tier1_4_Protect"], 10: ["Leadership_Tier2_9_Chart", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 11: ["Leadership_Tier2_9_Chart", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 12: ["Leadership_Tier2_9_Chart", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier1_2_Guardduty"], 13: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 14: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 15: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 16: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 17: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 18: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 19: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 20: ["Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 21: ["Leadership_Tier4_21_Training", "Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier3_13_Training", "Leadership_Tier1_5_Explore", "Leadership_Tier1_4_Protect", "Leadership_Tier2_7_Training"], 22: ["Leadership_Tier4_21_Training", "Leadership_Tier4_22r_Capturebandithq", "Leadership_Tier4_22_Guardclerics", "Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier1_5_Explore"], 23: ["Leadership_Tier4_23_Guardnoble", "Leadership_Tier4_21_Training", "Leadership_Tier4_22r_Capturebandithq", "Leadership_Tier4_22_Guardclerics", "Leadership_Tier4_23r_Securepilgrimage", "Leadership_Tier3_13_Patrol", "Leadership_Tier2_9_Chart", "Leadership_Tier1_5_Explore"], 24: ["Leadership_Tier4_22r_Capturebandithq", "Leadership_Tier4_24r_Killdragon", "Leadership_Tier4_24_Wizardsseneschal", "Leadership_Tier4_21_Protectmagic", "Leadership_Tier4_22_Guardclerics"], 25: ["Leadership_Tier4_22r_Capturebandithq", "Leadership_Tier4_24r_Killdragon", "Leadership_Tier4_24_Wizardsseneschal", "Leadership_Tier4_21_Protectmagic", "Leadership_Tier4_22_Guardclerics"], }, }] }; addProfile('Leadership',{ "profileName": "RP Coffer", //"profileDescription": "Does Resonance Stones, Enchanted Coffers and Thaumaturgic Stones.", "level": { "24": [ "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ], "25": [ "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_25_Battleelementalcultists", // Battle Elemental Cultists (2xEnchanted Coffer) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_25r_Huntexperiment", // Hunt down an escaped Experiment (Artifact Paraphenalia) 12h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ] } }, 'RP'); addProfile('Leadership',{ "profileName": "RP Double Coffer", //"profileDescription": "Does Resonance Stones and Enchanted Coffers.", "level": { "24": [ "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ], "25": [ "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_25_Battleelementalcultists", // Battle Elemental Cultists (2xEnchanted Coffer) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_25r_Huntexperiment", // Hunt down an escaped Experiment (Artifact Paraphenalia) 12h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ] } }, 'RP'); addProfile('Leadership',{ "profileName": "RP (Stacked Assets)", //"profileDescription": "Does Resonance Stones, Thaumaturgic Stones and Artifact Stones. Also places all of the rare tasks after the non-rare Resonance Stone task, so that high quality workers do not get misplaced over time.", "level": { "24": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ], "25": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_25r_Huntexperiment", // Hunt down an escaped Experiment (Artifact Paraphenalia) 12h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ] } }, 'RP'); addProfile('Leadership',{ "profileName": "RP Coffer (Stacked Assets)", //"profileDescription": "Does Resonance Stones, Enchanted Coffers and Thaumaturgic Stones. Also places all of the rare tasks after the non-rare Resonance Stone task, so that high quality workers do not get misplaced over time.", "level": { "24": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ], "25": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_25_Battleelementalcultists", // Battle Elemental Cultists (2xEnchanted Coffer) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_25r_Huntexperiment", // Hunt down an escaped Experiment (Artifact Paraphenalia) 12h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ] } }, 'RP'); addProfile('Leadership',{ "profileName": "RP Double Coffer (Stacked Assets)", //"profileDescription": "Does Resonance Stones and Enchanted Coffers. Also places all of the rare tasks after the non-rare Resonance Stone task, so that high quality workers do not get misplaced over time.", "level": { "24": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ], "25": [ "Leadership_Tier4_24_Wizardsseneschal", // Escort a Wizard's Seneschal (Resonant Bag) 16h "Leadership_Tier4_22r_Capturebandithq", // Capture Bandit Leader (Resonant Bag) Rare 8h "Leadership_Tier4_24r_Killdragon", // Kill a Young Dragon (Resonant Bag) Rare 12h "Leadership_Tier4_23_Guardnoble", // Guard Young Noble on Trip (Enchanted Coffer) 4h "Leadership_Tier4_25_Battleelementalcultists", // Battle Elemental Cultists (2xEnchanted Coffer) 12h "Leadership_Tier4_23r_Securepilgrimage", // Provide Security For Pilgrims (Enchanted Coffer) Rare 8h "Leadership_Tier4_21_Protectmagic", // Protect Magical Goods Market (Bandit Camp Clue, Thaumaturgic Bag) 12h "Leadership_Tier4_22_Guardclerics", // Guard Clerics of Ilmater (Artifact Paraphenalia) 8h "Leadership_Tier4_25r_Huntexperiment", // Hunt down an escaped Experiment (Artifact Paraphenalia) 12h "Leadership_Tier4_21r_Killelemental" // Kill Rogue Elemental (Thaumaturgic Bag) Rare 16h ] } }, 'RP'); addProfile("Leadership", { profileName: "Assets", isProfileActive: true, level: { 3: ["Leadership_Tier3_13_Recruit", "Leadership_Tier2_7_Recruit", "Leadership_Tier1_2_Recruit"], 4: '+25' } }); definedTask["Winterevent"] = { taskListName: "Winterevent", taskName: "Winterevent", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Event_Winter_Tier0_Intro"], 1: ["Event_Winter_Tier1_Rankup", /*"Event_Winter_Tier1_Shiny_Lure",*/ "Event_Winter_Tier1_Refine", "Event_Winter_Tier1_Gather" ], 2: ["Event_Winter_Tier1_Rankup_2", /*"Event_Winter_Tier1_Fishingpole_Blue","Event_Winter_Tier1_Shiny_Lure_Mass",*/ "Event_Winter_Tier1_Refine_2", "Event_Winter_Tier1_Gather_2" ], 3: [ /*"Event_Winter_Tier1_Heros_Feast","Event_Winter_Tier1_Lightwine","Event_Winter_Tier1_Sparkliest_Gem","Event_Winter_Tier1_Mesmerizing_Lure",*/ "Event_Winter_Tier1_Gather_3" ], }, }] }; definedTask["SiegeEvent"] = { taskListName: "SiegeEvent", taskName: "Event_Siege", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Event_Siege_Tier0_Intro"], // Hire a Siege Master //1:["Event_Siege_Tier1_Donate_Minorinjury"], // Create Defense Supplies from Minor Injury Kits //1:["Event_Siege_Tier1_Donate_Injury"], // Create Defense Supplies from Injury Kits //1:["Event_Siege_Tier1_Donate_Majorinjury"], // Create Defense Supplies from Major Injury Kits //1:["Event_Siege_Tier1_Donate_Altar_10"], // Create Defense Supplies from 10 Portable Altars //1:["Event_Siege_Tier1_Donate_Altar_50"], // Create Defense Supplies from 50 Portable Altars //1:["Event_Siege_Tier1_Donate_Resources_T2"], // Create Defense Supplies from Tier 2 crafting resources //1:["Event_Siege_Tier1_Donate_Resources_T3"], // Create Defense Supplies from Tier 3 crafting resources 1: ["Event_Siege_Tier1_Donate_Resources_T3", "Event_Siege_Tier1_Donate_Resources_T2", "Event_Siege_Tier1_Donate_Minorinjury", "Event_Siege_Tier1_Donate_Injury", "Event_Siege_Tier1_Donate_Majorinjury", "Event_Siege_Tier1_Donate_Altar_10"], }, }] }; definedTask["Blackice"] = { taskListName: "Blackice", taskName: "Blackice", taskDefaultPriority: 0, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 1: ["Blackice_Tier1_Process_Blackice","Blackice_Tier1_Recruit_Blackice_Smith"], 2: ["Blackice_Tier1_Process_Blackice","Blackice_Tier2_Recruit_Assistant_Cryomancer"], 3: ["Blackice_Tier1_Process_Blackice","Blackice_Tier2_Recruit_Assistant_Cryomancer"], 4: ["Blackice_Tier1_Process_Blackice","Blackice_Tier2_Recruit_Assistant_Cryomancer"], 5: ["Blackice_Tier1_Process_Blackice","Blackice_Tier2_Recruit_Assistant_Cryomancer"], /* 1:["Forge Hammerstone Pick","Gather Raw Black Ice","Truesilver Pick Grip","Process Raw Black Ice","Upgrade Chillwright","Hire an additional Chillwright"], 2:["Forge Hammerstone Pick","Gather Raw Black Ice","Truesilver Pick Grip","Process Raw Black Ice","Upgrade Chillwright","Hire an additional Chillwright"], 3:["Forge Hammerstone Pick","Gather Raw Black Ice","Truesilver Pick Grip","Process Raw Black Ice","Upgrade Chillwright","Hire an additional Chillwright"], */ }, }] }; definedTask["Jewelcrafting"] = { taskListName: "Jewelcrafting", taskName: "Jewelcrafting", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Jewelcrafting_Tier0_Intro"], 1: ["Jewelcrafting_Tier1_Waist_Offense_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 2: ["Jewelcrafting_Tier1_Waist_Offense_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 3: ["Jewelcrafting_Tier1_Neck_Offense_1", "Jewelcrafting_Tier1_Waist_Offense_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 4: ["Jewelcrafting_Tier1_Neck_Offense_1", "Jewelcrafting_Tier1_Waist_Misc_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 5: ["Jewelcrafting_Tier1_Neck_Offense_1", "Jewelcrafting_Tier1_Waist_Misc_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 6: ["Jewelcrafting_Tier1_Neck_Misc_1", "Jewelcrafting_Tier1_Waist_Misc_1", "Jewelcrafting_Tier1_Refine_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 7: ["Jewelcrafting_Tier1_Neck_Misc_1", "Jewelcrafting_Tier2_Waist_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 8: ["Jewelcrafting_Tier1_Neck_Misc_1", "Jewelcrafting_Tier2_Waist_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 9: ["Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Waist_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 10: ["Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Waist_Misc_2", "Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 11: ["Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Waist_Misc_2", "Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 12: ["Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Waist_Misc_2", "Jewelcrafting_Tier2_Neck_Offense_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 13: ["Jewelcrafting_Tier2_Neck_Misc_2", "Jewelcrafting_Tier2_Waist_Misc_2", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 14: ["Jewelcrafting_Tier2_Neck_Misc_2", "Jewelcrafting_Tier3_Waist_Offense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 15: ["Jewelcrafting_Tier2_Neck_Misc_2", "Jewelcrafting_Tier3_Waist_Offense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 16: ["Jewelcrafting_Tier3_Neck_Offense_3", "Jewelcrafting_Tier3_Waist_Defense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 17: ["Jewelcrafting_Tier3_Neck_Defense_3", "Jewelcrafting_Tier3_Waist_Defense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 18: ["Jewelcrafting_Tier3_Neck_Defense_3", "Jewelcrafting_Tier3_Waist_Defense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 19: ["Jewelcrafting_Tier3_Neck_Defense_3", "Jewelcrafting_Tier3_Waist_Defense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 20: ["Jewelcrafting_Tier3_Neck_Misc_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 21: ["Jewelcrafting_Tier3_Neck_Misc_3", "Jewelcrafting_Tier4_Refine_Basic", "Jewelcrafting_Tier4_Gather_Basic", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 22: ["Jewelcrafting_Tier4_Neck_Base_3", "Jewelcrafting_Tier4_Refine_Basic", "Jewelcrafting_Tier4_Gather_Basic", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 23: ["Jewelcrafting_Tier4_Neck_Defense_3", "Jewelcrafting_Tier4_Neck_Offense_3", "Jewelcrafting_Tier4_Gather_Basic", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 24: ["Jewelcrafting_Tier4_Neck_Misc_3", "Jewelcrafting_Tier3_Neck_Misc_3", "Jewelcrafting_Tier4_Gather_Basic", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], // basic resources for lvl 16 and 15 items. 25: ["Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], }, }] }; addProfile("Jewelcrafting", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Jewelcrafting_Tier0_Intro"], 1: ["Jewelcrafting_Tier1_Refine_Basic_Mass", "Jewelcrafting_Tier1_Gather_Basic"], 2: '+25', 7: ["Jewelcrafting_Tier2_Refine_Basic_Mass"], 8: '+25', 14: ["Jewelcrafting_Tier3_Refine_Basic_Mass"], 15: '+25', 21: ["Jewelcrafting_Tier4_Refine_Basic_Mass"], 22: '+25', }, }); addProfile("Jewelcrafting", { profileName: "21->25 gather", isProfileActive: true, level: { 21: ["Jewelcrafting_Tier4_Refine_Basic_Mass", "Jewelcrafting_Tier4_Gather_Basic"], 22: '+25' }, }); addProfile("Jewelcrafting", { profileName: "Craft Purple Neck", isProfileActive: true, level: { // we care only about neck items that we can start pile up at lvl 16 16: ["Jewelcrafting_Tier3_Neck_Offense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 17: '+25', 25: ["Jewelcrafting_Tier4_Neck_Offense_4_Purple", //Exquisite Adamant Necklace of Piercing "Jewelcrafting_Tier4_Neck_Misc_4_Purple", // Exquisite Adamant Necklace of Recovery "Jewelcrafting_Tier4_Neck_Defense_4_Purple",//Exquisite Adamant Necklace of Regeneration "Jewelcrafting_Tier4_Ring_Offense_4_Purple",//Exquisite Adamant Ring of Piercing "Jewelcrafting_Tier4_Ring_Misc_4_Purple",//Exquisite Adamant Ring of Recovery "Jewelcrafting_Tier4_Ring_Defense_4_Purple",//Exquisite Adamant Ring of Regeneration "Jewelcrafting_Tier3_Neck_Offense_3", "Jewelcrafting_Tier2_Refine_Basic", "Jewelcrafting_Tier1_Refine_Basic"], }, }); addProfile("Jewelcrafting", { profileName: "Craft Purple Rings", isProfileActive: true, level: { // we care only about neck items that we can start pile up at lvl 15 15: ["Jewelcrafting_Tier3_Ring_Offense_3", "Jewelcrafting_Tier3_Refine_Basic", "Jewelcrafting_Tier3_Gather_Basic", "Jewelcrafting_Tier2_Gather_Basic", "Jewelcrafting_Tier1_Gather_Basic"], 16:'+25', 25: ["Jewelcrafting_Tier4_Ring_Offense_4_Purple", //Exquisite Adamant Ring of Piercing "Jewelcrafting_Tier4_Ring_Misc_4_Purple", //Exquisite Adamant Ring of Recovery "Jewelcrafting_Tier4_Ring_Defense_4_Purple", //Exquisite Adamant Ring of Regeneration "Jewelcrafting_Tier4_Neck_Offense_4_Purple", //Exquisite Adamant Necklace of Piercing "Jewelcrafting_Tier4_Neck_Misc_4_Purple", // Exquisite Adamant Necklace of Recovery "Jewelcrafting_Tier4_Neck_Defense_4_Purple",//Exquisite Adamant Necklace of Regeneration "Jewelcrafting_Tier3_Ring_Offense_3", "Jewelcrafting_Tier3_Refine_Basic"] }, }); addProfile("Jewelcrafting", { profileName: "Craft Purple lvl 25", isProfileActive: true, level: { 25: ["Jewelcrafting_Tier4_Ring_Offense_4_Purple", //Exquisite Adamant Ring of Piercing "Jewelcrafting_Tier4_Ring_Misc_4_Purple", //Exquisite Adamant Ring of Recovery "Jewelcrafting_Tier4_Ring_Defense_4_Purple", //Exquisite Adamant Ring of Regeneration "Jewelcrafting_Tier4_Neck_Offense_4_Purple", //Exquisite Adamant Necklace of Piercing "Jewelcrafting_Tier4_Neck_Misc_4_Purple", // Exquisite Adamant Necklace of Recovery - !!check name!! "Jewelcrafting_Tier4_Neck_Defense_4_Purple",//Exquisite Adamant Necklace of Regeneration "Jewelcrafting_Tier3_Refine_Basic"//timeout task ], }, }); definedTask["Mailsmithing"] = { taskListName: "Mailsmithing", taskName: "Armorsmithing_Med", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Med_Armorsmithing_Tier0_Intro"], 1: ["Med_Armorsmithing_Tier1_Gather_Basic"], 2: ["Med_Armorsmithing_Tier1_Chain_Armor_1", "Med_Armorsmithing_Tier1_Chain_Pants_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 3: ["Med_Armorsmithing_Tier1_Chain_Armor_1", "Med_Armorsmithing_Tier1_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 4: ["Med_Armorsmithing_Tier1_Chain_Armor_1", "Med_Armorsmithing_Tier1_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 5: ["Med_Armorsmithing_Tier1_Chain_Armor_Set_1", "Med_Armorsmithing_Tier1_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 6: ["Med_Armorsmithing_Tier1_Chain_Armor_Set_1", "Med_Armorsmithing_Tier1_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 7: ["Med_Armorsmithing_Tier1_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt", "Med_Armorsmithing_Tier1_Gather_Basic", "Med_Armorsmithing_Tier1_Gather_Basic"], 8: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt", "Med_Armorsmithing_Tier1_Gather_Basic"], 9: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt", "Med_Armorsmithing_Tier1_Gather_Basic"], 10: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt_2", "Med_Armorsmithing_Tier1_Gather_Basic", "Med_Armorsmithing_Tier1_Gather_Basic"], 11: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_2", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt_2", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 12: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_2", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt_2", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 13: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_2", "Med_Armorsmithing_Tier2_Chain_Boots_Set_1", "Med_Armorsmithing_Tier2_Chain_Shirt_2", "Med_Armorsmithing_Tier2_Chain_Pants_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 14: ["Med_Armorsmithing_Tier2_Chain_Armor_Set_1", "Med_Armorsmithing_Tier2_Chain_Pants_2", "Med_Armorsmithing_Tier3_Chain_Shirt", "Med_Armorsmithing_Tier3_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 15: ["Med_Armorsmithing_Tier3_Chain_Armor_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants", "Med_Armorsmithing_Tier3_Chain_Shirt2", "Med_Armorsmithing_Tier3_Chain_Boots_Set_1", "Med_Armorsmithing_Tier1_Gather_Basic"], 16: ["Med_Armorsmithing_Tier3_Chain_Armor_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants2", "Med_Armorsmithing_Tier3_Chain_Shirt2", "Med_Armorsmithing_Tier3_Chain_Helm_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants", "Med_Armorsmithing_Tier1_Gather_Basic"], 17: ["Med_Armorsmithing_Tier3_Chain_Armor_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants2", "Med_Armorsmithing_Tier3_Chain_Shirt2", "Med_Armorsmithing_Tier3_Chain_Helm_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants", "Med_Armorsmithing_Tier1_Gather_Basic"], 18: ["Med_Armorsmithing_Tier3_Chain_Armor_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants2", "Med_Armorsmithing_Tier3_Chain_Shirt2", "Med_Armorsmithing_Tier3_Chain_Helm_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants", "Med_Armorsmithing_Tier1_Gather_Basic"], 19: ["Med_Armorsmithing_Tier3_Chain_Armor_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants2", "Med_Armorsmithing_Tier3_Chain_Shirt2", "Med_Armorsmithing_Tier3_Chain_Helm_Set_1", "Med_Armorsmithing_Tier3_Chain_Pants", "Med_Armorsmithing_Tier1_Gather_Basic"], 20: ["Med_Armorsmithing_Tier3_Chain_Pants"], 21: ["Med_Armorsmithing_Tier3_Chain_Pants"], 22: ["Med_Armorsmithing_Tier3_Chain_Pants"], 23: ["Med_Armorsmithing_Tier3_Chain_Pants"], 24: ["Med_Armorsmithing_Tier3_Chain_Pants"], 25: ["Crafted_Med_Armorsmithing_T4_Refine_Basic", "Crafted_Med_Armorsmithing_T4_Gather_Basic"], } }] }; addProfile("Mailsmithing", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Med_Armorsmithing_Tier0_Intro"], 1: ["Med_Armorsmithing_Tier1_Refine_Basic_Mass", "Med_Armorsmithing_Tier1_Gather_Basic"], 2: "+25", 7: ["Med_Armorsmithing_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Med_Armorsmithing_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Crafted_Med_Armorsmithing_T4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Mailsmithing", { profileName: "21->25 gather", isProfileActive: true, level: { 21: ["Crafted_Med_Armorsmithing_T4_Refine_Basic_Mass", "Crafted_Med_Armorsmithing_T4_Gather_Basic_Mass"], 22: "+25", 25: ["Crafted_Med_Armorsmithing_T4_Refine_Basic", "Crafted_Med_Armorsmithing_T4_Gather_Basic"], }, }); addProfile("Mailsmithing", { profileName: "Berserker's Chainmail and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Green_Shirt_Dps",//Berserker's Elemental Chainmail "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Berserker's Chausses and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Green_Pants_Dps",//Berserker's Elemental Chausses "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Soldier's Chainmail and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Green_Shirt_Tank",//Soldier's Elemental Chainmail "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Soldier's Chausses and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Green_Pants_Tank",//Soldier's Elemental Chausses "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Zealot's Chainmail and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Green_Shirt_Dps",//Zealot's Elemental Chainmail "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Zealot's Chausses and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Green_Pants_Dps",//Zealot's Elemental Chausses "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Prelate's Chainmail and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Green_Shirt_Tank",//Prelate's Elemental Chainmail "Med_Armorsmithing_Tier3_Refine_Basic" ], }, }); addProfile("Mailsmithing", { profileName: "Prelate's Chausses and rares", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Green_Pants_Tank",//Prelate's Elemental Chainmail "Med_Armorsmithing_Tier3_Refine_Basic" ] }, }); addProfile("Mailsmithing", { profileName: "craft rares only", isProfileActive: true, level: { 25: ["Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Tank", //Prelate's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Tank", //Prelate's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Chain_T4_Purple_Pants_Dps", //Zealot's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Chain_T4_Purple_Shirt_Dps", //Zealot's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Soldier's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Dps", //Soldier's Exquisite Elemental Chainmail "Crafted_Med_Armorsmithing_Scale_T4_Purple_Pants_Dps", //Berserker's Exquisite Elemental Chausses "Crafted_Med_Armorsmithing_Scale_T4_Purple_Shirt_Tank", //Berserker's Exquisite Elemental Chainmail "Med_Armorsmithing_Tier2_Refine_Basic"] } }); addProfile("Mailsmithing", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Med_Armorsmithing_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Platesmithing"] = { taskListName: "Platesmithing", taskName: "Armorsmithing_Heavy", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Hvy_Armorsmithing_Tier0_Intro"], 1: ["Hvy_Armorsmithing_Tier1_Plate_Boots_1", "Hvy_Armorsmithing_Tier1_Plate_Shirt_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 2: ["Hvy_Armorsmithing_Tier1_Plate_Armor_1", "Hvy_Armorsmithing_Tier1_Plate_Pants_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 3: ["Hvy_Armorsmithing_Tier1_Plate_Armor_1", "Hvy_Armorsmithing_Tier1_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 4: ["Hvy_Armorsmithing_Tier1_Plate_Armor_1", "Hvy_Armorsmithing_Tier1_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 5: ["Hvy_Armorsmithing_Tier1_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier1_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 6: ["Hvy_Armorsmithing_Tier1_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier1_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 7: ["Hvy_Armorsmithing_Tier1_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt", "Hvy_Armorsmithing_Tier2_Shield_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 8: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 9: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 10: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt_2", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 11: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_2", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt_2", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 12: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_2", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt_2", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 13: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_2", "Hvy_Armorsmithing_Tier2_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Shirt_2", "Hvy_Armorsmithing_Tier2_Plate_Pants_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 14: ["Hvy_Armorsmithing_Tier2_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier2_Plate_Pants_2", "Hvy_Armorsmithing_Tier3_Plate_Shirt", "Hvy_Armorsmithing_Tier3_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 15: ["Hvy_Armorsmithing_Tier3_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants", "Hvy_Armorsmithing_Tier3_Plate_Shirt2", "Hvy_Armorsmithing_Tier3_Plate_Boots_Set_1", "Hvy_Armorsmithing_Tier1_Gather_Basic", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 16: ["Hvy_Armorsmithing_Tier3_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants2", "Hvy_Armorsmithing_Tier3_Plate_Shirt2", "Hvy_Armorsmithing_Tier3_Plate_Helm_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 17: ["Hvy_Armorsmithing_Tier3_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants2", "Hvy_Armorsmithing_Tier3_Plate_Shirt2", "Hvy_Armorsmithing_Tier3_Plate_Helm_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 18: ["Hvy_Armorsmithing_Tier3_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants2", "Hvy_Armorsmithing_Tier3_Plate_Shirt2", "Hvy_Armorsmithing_Tier3_Plate_Helm_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 19: ["Hvy_Armorsmithing_Tier3_Plate_Armor_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants2", "Hvy_Armorsmithing_Tier3_Plate_Shirt2", "Hvy_Armorsmithing_Tier3_Plate_Helm_Set_1", "Hvy_Armorsmithing_Tier3_Plate_Pants", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 20: ["Hvy_Armorsmithing_Tier3_Plate_Pants"], 21: ["Hvy_Armorsmithing_Tier3_Plate_Pants"], 22: ["Hvy_Armorsmithing_Tier3_Plate_Pants"], 23: ["Hvy_Armorsmithing_Tier3_Plate_Pants"], 24: ["Hvy_Armorsmithing_Tier3_Plate_Pants"], 25: ["Crafted_Hvy_Armorsmithing_T4_Refine_Basic_Mass", "Crafted_Hvy_Armorsmithing_T4_Gather_Basic_Mass"], }, }] }; addProfile("Platesmithing", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Hvy_Armorsmithing_Tier0_Intro"], 1: ["Hvy_Armorsmithing_Tier1_Refine_Basic_Mass", "Hvy_Armorsmithing_Tier1_Gather_Basic"], 2: "+25", 7: ["Hvy_Armorsmithing_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Hvy_Armorsmithing_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Crafted_Hvy_Armorsmithing_T4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Platesmithing", { profileName: "21->25 gather", isProfileActive: true, level: { 21: ["Crafted_Hvy_Armorsmithing_T4_Refine_Basic_Mass", "Crafted_Hvy_Armorsmithing_T4_Gather_Basic_Mass"], 22: "+25", }, }); addProfile("Platesmithing", { profileName: "craft purple lvl 25", isProfileActive: true, level: { 25: ["Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Tank", //Defender's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Dps", //Warrior's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Tank",//Defender's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Dps", //Warrior's Exquisite Elemental Chausses "Hvy_Armorsmithing_Tier3_Refine_Basic"//Mithral plates ] } }, "21->25 gather"); addProfile("Platesmithing", { profileName: "craft Exq. Tank shirt", isProfileActive: true, level: { 25: ["Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Tank", //Defender's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Dps", //Warrior's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Tank",//Defender's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Dps", //Warrior's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Green_Shirt_Tank", "Hvy_Armorsmithing_Tier3_Refine_Basic"//Mithral plates ] } }, "21->25 gather"); addProfile("Platesmithing", { profileName: "craft Exq. Warrior shirt", isProfileActive: true, level: { 25: ["Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Dps", //Warrior's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Tank", //Defender's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Tank",//Defender's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Dps", //Warrior's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Green_Shirt_Dps", "Hvy_Armorsmithing_Tier3_Refine_Basic"//Mithral plates ] } }, "21->25 gather"); addProfile("Platesmithing", { profileName: "craft Exq. Tank pants", isProfileActive: true, level: { 25: ["Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Tank",//Defender's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Dps", //Warrior's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Dps", //Warrior's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Tank", //Defender's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Green_Pants_Tank", "Hvy_Armorsmithing_Tier3_Refine_Basic"//Mithral plates ] } }, "21->25 gather"); addProfile("Platesmithing", { profileName: "craft Exq. Warrior pants", isProfileActive: true, level: { 25: ["Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Dps", //Warrior's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Dps", //Warrior's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Shirt_Tank", //Defender's Exquisite Elemental Chainmail "Crafted_Hvy_Armorsmithing_T4_Purple_Pants_Tank",//Defender's Exquisite Elemental Chausses "Crafted_Hvy_Armorsmithing_T4_Green_Pants_Dps", "Hvy_Armorsmithing_Tier3_Refine_Basic"//Mithral plates ] } }, "21->25 gather"); addProfile("Platesmithing", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Hvy_Armorsmithing_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Leatherworking"] = { taskListName: "Leatherworking", taskName: "Leatherworking", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Leatherworking_Tier0_Intro_1"], 1: ["Leatherworking_Tier1_Leather_Boots_1", "Leatherworking_Tier1_Leather_Shirt_1", "Leatherworking_Tier1_Gather_Basic"], 2: ["Leatherworking_Tier1_Leather_Armor_1", "Leatherworking_Tier1_Leather_Pants_1", "Leatherworking_Tier1_Gather_Basic"], 3: ["Leatherworking_Tier1_Leather_Armor_1", "Leatherworking_Tier1_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 4: ["Leatherworking_Tier1_Leather_Armor_1", "Leatherworking_Tier1_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 5: ["Leatherworking_Tier1_Leather_Armor_Set_1", "Leatherworking_Tier1_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 6: ["Leatherworking_Tier1_Leather_Armor_Set_1", "Leatherworking_Tier1_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 7: ["Leatherworking_Tier1_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt", "Leatherworking_Tier1_Gather_Basic"], 8: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt", "Leatherworking_Tier1_Gather_Basic"], 9: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt", "Leatherworking_Tier1_Gather_Basic"], 10: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt_2", "Leatherworking_Tier1_Gather_Basic"], 11: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_2", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt_2", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier1_Gather_Basic"], 12: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_2", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt_2", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier1_Gather_Basic"], 13: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_2", "Leatherworking_Tier2_Leather_Boots_Set_1", "Leatherworking_Tier2_Leather_Shirt_2", "Leatherworking_Tier2_Leather_Pants_1", "Leatherworking_Tier1_Gather_Basic"], 14: ["Leatherworking_Tier2_Leather_Armor_Set_1", "Leatherworking_Tier2_Leather_Pants_2", "Ornate Leatherworking_Tier1_Leather_Shirt_1", "Leatherworking_Tier3_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 15: ["Leatherworking_Tier3_Leather_Armor_Set_1", "Leatherworking_Tier3_Leather_Pants", "Leatherworking_Tier3_Leather_Shirt2", "Leatherworking_Tier3_Leather_Boots_Set_1", "Leatherworking_Tier1_Gather_Basic"], 16: ["Leatherworking_Tier3_Leather_Armor_Set_1", "Leatherworking_Tier3_Leather_Pants2", "Leatherworking_Tier3_Leather_Shirt2", "Leatherworking_Tier3_Leather_Helm_Set_1", "Leatherworking_Tier3_Leather_Pants", "Leatherworking_Tier1_Gather_Basic"], 17: ["Leatherworking_Tier3_Leather_Armor_Set_1", "Leatherworking_Tier3_Leather_Pants2", "Leatherworking_Tier3_Leather_Shirt2", "Leatherworking_Tier3_Leather_Helm_Set_1", "Leatherworking_Tier3_Leather_Pants", "Leatherworking_Tier1_Gather_Basic"], 18: ["Leatherworking_Tier3_Leather_Armor_Set_1", "Leatherworking_Tier3_Leather_Pants2", "Leatherworking_Tier3_Leather_Shirt2", "Leatherworking_Tier3_Leather_Helm_Set_1", "Leatherworking_Tier3_Leather_Pants", "Leatherworking_Tier1_Gather_Basic"], 19: ["Leatherworking_Tier3_Leather_Armor_Set_1", "Leatherworking_Tier3_Leather_Pants2", "Leatherworking_Tier3_Leather_Shirt2", "Leatherworking_Tier3_Leather_Helm_Set_1", "Leatherworking_Tier3_Leather_Pants", "Leatherworking_Tier1_Gather_Basic"], //19:["Leather Armor +4","Fancy Leather Pants","Fancy Leather Shirt","Leather Helm +4","Ornate Leather Pants","Upgrade Tanner","Upgrade Skinner","Hire an additional Skinner"], 20: ["Leatherworking_Tier3_Leather_Pants"], 21: ["Leatherworking_Tier3_Leather_Pants"], 22: ["Leatherworking_Tier3_Leather_Pants"], 23: ["Leatherworking_Tier3_Leather_Pants"], 24: ["Leatherworking_Tier3_Leather_Pants"], 25: ["Leatherworking_Tier4_Refine_Basic", "Leatherworking_Tier4_Gather_Basic"], }, } ] }; addProfile("Leatherworking", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Leatherworking_Tier0_Intro_1"], 1: ["Leatherworking_Tier1_Refine_Basic_Mass", "Leatherworking_Tier1_Gather_Basic"], 2: "+25", 7: ["Leatherworking_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Leatherworking_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Leatherworking_Tier4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Leatherworking", { profileName: "20->25 gather", isProfileActive: true, level: { 20: ["Leatherworking_Tier3_Leather_Pants"], 21: ["Leatherworking_Tier4_Refine_Basic_Mass", "Leatherworking_Tier4_Gather_Basic"], 22: "+25", 25: ["Leatherworking_Tier4_Refine_Basic", "Leatherworking_Tier4_Gather_Basic"], }, }); addProfile("Leatherworking", { profileName: "craft purples only", level: { //purples first. shirts > tunics > pants. 25: ["Leatherworking_Tier4_Leather_Shirt_Special_2", //Exquisite Elemental Shirt "Leatherworking_Tier4_Leather_Shirt_Special_2_Set2", //Exquisite Elemental Tunic "Leatherworking_Tier4_Leather_Pants_Special_2_Set2", //Exquisite Elemental Trousers "Leatherworking_Tier4_Leather_Pants_Special_2", //Exquisite Elemental Pants "Leatherworking_Tier3_Gather_Basic"] } }); addProfile("Leatherworking", { profileName: "craft Elemental Shirts", level: { //purples first. shirts > tunics > pants. 25: ["Leatherworking_Tier4_Leather_Shirt_Special_2", // Exquisite Elemental Shirt "Leatherworking_Tier4_Leather_Shirt_Special_2_Set2", // Exquisite Elemental Tunic "Leatherworking_Tier4_Leather_Pants_Special_2_Set2", // Exquisite Elemental Trousers "Leatherworking_Tier4_Leather_Pants_Special_2", // Exquisite Elemental Pants "Leatherworking_Tier4_Leather_Shirt2", // Elemental Leather Shirt "Leatherworking_Tier3_Gather_Basic"] } }); addProfile("Leatherworking", { profileName: "craft Elemental Tunic", level: { //purples first. shirts > tunics > pants. 25: ["Leatherworking_Tier4_Leather_Shirt_Special_2_Set2", // Exquisite Elemental Tunic "Leatherworking_Tier4_Leather_Shirt_Special_2", // Exquisite Elemental Shirt "Leatherworking_Tier4_Leather_Pants_Special_2_Set2", // Exquisite Elemental Trousers "Leatherworking_Tier4_Leather_Pants_Special_2", // Exquisite Elemental Pants "Leatherworking_Tier4_Leather_Shirt2_Set2", // Elemental Leather Tunic "Leatherworking_Tier3_Gather_Basic"] } }); addProfile("Leatherworking", { profileName: "craft Elemental Trousers", level: { //purples first. shirts > tunics > pants. 25: ["Leatherworking_Tier4_Leather_Pants_Special_2_Set2", // Exquisite Elemental Trousers "Leatherworking_Tier4_Leather_Pants_Special_2", // Exquisite Elemental Pants "Leatherworking_Tier4_Leather_Shirt_Special_2_Set2", // Exquisite Elemental Tunic "Leatherworking_Tier4_Leather_Shirt_Special_2", // Exquisite Elemental Shirt "Leatherworking_Tier4_Leather_Pants2_Set2", // Elemental Leather Trousers "Leatherworking_Tier3_Gather_Basic"] } }); addProfile("Leatherworking", { profileName: "craft Elemental Pants", level: { //purples first. shirts > tunics > pants. 25: ["Leatherworking_Tier4_Leather_Pants_Special_2", // Exquisite Elemental Pants "Leatherworking_Tier4_Leather_Pants_Special_2_Set2", // Exquisite Elemental Trousers "Leatherworking_Tier4_Leather_Shirt_Special_2_Set2", // Exquisite Elemental Tunic "Leatherdeworking_Tier4_Leather_Shirt_Special_2", // Exquisite Elemental Shirt "Leatherworking_Tier4_Leather_Pants2", // Elemental Leather Pants "Leatherworking_Tier3_Gather_Basic"] } }); addProfile("Leatherworking", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Leatherworking_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Tailoring"] = { taskListName: "Tailoring", taskName: "Tailoring", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Tailoring_Tier0_Intro"], 1: ["Tailoring_Tier1_Cloth_Boots_1", "Tailoring_Tier1_Cloth_Shirt_1", "Tailoring_Tier1_Gather_Basic"], 2: ["Tailoring_Tier1_Cloth_Armor_1", "Tailoring_Tier1_Cloth_Pants_1", "Tailoring_Tier1_Gather_Basic"], 3: ["Tailoring_Tier1_Cloth_Armor_1", "Tailoring_Tier1_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 4: ["Tailoring_Tier1_Cloth_Armor_1", "Tailoring_Tier1_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 5: ["Tailoring_Tier1_Cloth_Armor_Set_1", "Tailoring_Tier1_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 6: ["Tailoring_Tier1_Cloth_Armor_Set_1", "Tailoring_Tier1_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 7: ["Tailoring_Tier1_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt", "Tailoring_Tier1_Gather_Basic", "Tailoring_Tier1_Gather_Basic"], 8: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt", "Tailoring_Tier1_Gather_Basic"], 9: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt", "Tailoring_Tier1_Gather_Basic"], 10: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt_2", "Tailoring_Tier1_Gather_Basic"], 11: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_2", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt_2", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier1_Gather_Basic"], 12: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_2", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt_2", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier1_Gather_Basic"], 13: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_2", "Tailoring_Tier2_Cloth_Boots_Set_1", "Tailoring_Tier2_Cloth_Shirt_2", "Tailoring_Tier2_Cloth_Pants_1", "Tailoring_Tier1_Gather_Basic"], 14: ["Tailoring_Tier2_Cloth_Armor_Set_1", "Tailoring_Tier2_Cloth_Pants_2", "Tailoring_Tier3_Cloth_Shirt", "Tailoring_Tier3_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 15: ["Tailoring_Tier3_Cloth_Armor_Set_1", "Tailoring_Tier3_Cloth_Pants", "Tailoring_Tier3_Cloth_Shirt2", "Tailoring_Tier3_Cloth_Boots_Set_1", "Tailoring_Tier1_Gather_Basic"], 16: ["Tailoring_Tier3_Cloth_Armor_Set_1", "Tailoring_Tier3_Cloth_Pants", "Tailoring_Tier3_Cloth_Shirt2", "Tailoring_Tier3_Cloth_Helm_Set_1", "Tailoring_Tier1_Gather_Basic"], 17: ["Tailoring_Tier3_Cloth_Armor_Set_1", "Tailoring_Tier3_Cloth_Pants2_Set2", "Tailoring_Tier3_Cloth_Shirt2", "Tailoring_Tier3_Cloth_Helm_Set_1", "Tailoring_Tier1_Gather_Basic"], 18: ["Tailoring_Tier3_Cloth_Armor_Set_3", "Tailoring_Tier3_Cloth_Armor_Set_2", "Tailoring_Tier3_Cloth_Armor_Set_1", "Tailoring_Tier3_Cloth_Pants2_Set2", "Tailoring_Tier3_Cloth_Shirt2", "Tailoring_Tier3_Cloth_Helm_Set_1", "Tailoring_Tier3_Cloth_Pants", "Tailoring_Tier1_Gather_Basic"], 19: ["Tailoring_Tier3_Cloth_Armor_Set_3", "Tailoring_Tier3_Cloth_Armor_Set_2", "Tailoring_Tier3_Cloth_Armor_Set_1", "Tailoring_Tier3_Cloth_Pants2_Set2", "Tailoring_Tier3_Cloth_Shirt2", "Tailoring_Tier3_Cloth_Helm_Set_1", "Tailoring_Tier3_Cloth_Pants", "Tailoring_Tier1_Gather_Basic"], //19:["Cloth Robes +4","Fancy Cloth Pants","Fancy Cloth Shirt","Cloth Cap +4","Ornate Cloth Pants","Upgrade Outfitter","Upgrade Weaver","Hire an additional Weaver"], 20: ["Tailoring_Tier3_Cloth_Pants"], 21: ["Tailoring_Tier3_Cloth_Pants"], 22: ["Tailoring_Tier3_Cloth_Pants"], 23: ["Tailoring_Tier3_Cloth_Pants"], 24: ["Tailoring_Tier3_Cloth_Pants"], 25: ["Crafted_Tailoring_T4_Refine_Basic", "Crafted_Tailoring_T4_Gather_Basic"], }, }] }; addProfile("Tailoring", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Tailoring_Tier0_Intro"], 1: ["Tailoring_Tier1_Refine_Basic_Mass", "Tailoring_Tier1_Gather_Basic"], 2: "+25", 7: ["Tailoring_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Tailoring_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Crafted_Tailoring_T4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Tailoring", { profileName: "21->25 gather", isProfileActive: true, level: { 21: ["Crafted_Tailoring_T4_Refine_Basic_Mass", "Crafted_Tailoring_T4_Gather_Basic_Mass"], 22: "+25", 25: ["Crafted_Tailoring_T4_Refine_Basic", "Crafted_Tailoring_T4_Gather_Basic"], }, }); addProfile("Tailoring", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Tailoring_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Artificing"] = { taskListName: "Artificing", taskName: "Artificing", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Artificing_Tier0_Intro_1"], 1: ["Artificing_Tier1_Pactblade_Convergence_1", "Artificing_Tier1_Symbol_Virtuous_1", "Artificing_Tier1_Gather_Basic"], 2: ["Artificing_Tier1_Pactblade_Convergence_1", "Artificing_Tier1_Icon_Virtuous_1", "Artificing_Tier1_Gather_Basic"], 3: ["Artificing_Tier1_Pactblade_Convergence_1", "Artificing_Tier1_Icon_Virtuous_1", "Artificing_Tier1_Gather_Basic"], 4: ["Artificing_Tier1_Pactblade_Convergence_2", "Artificing_Tier1_Icon_Virtuous_2", "Artificing_Tier1_Gather_Basic"], 5: ["Artificing_Tier1_Pactblade_Convergence_2", "Artificing_Tier1_Icon_Virtuous_2", "Artificing_Tier1_Gather_Basic"], 6: ["Artificing_Tier1_Pactblade_Convergence_2", "Artificing_Tier1_Icon_Virtuous_2", "Artificing_Tier1_Gather_Basic"], 7: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier1_Icon_Virtuous_2", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 8: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 9: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 10: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 11: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 12: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 13: ["Artificing_Tier2_Pactblade_Temptation_3", "Artificing_Tier2_Icon_Virtuous_3", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 14: ["Artificing_Tier3_Pactblade_Temptation_4", "Artificing_Tier3_Icon_Virtuous_4", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 15: ["Artificing_Tier3_Pactblade_Temptation_4", "Artificing_Tier3_Icon_Virtuous_4", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 16: ["Artificing_Tier3_Pactblade_Temptation_4", "Artificing_Tier3_Icon_Virtuous_4", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 17: ["Artificing_Tier3_Pactblade_Temptation_5", "Artificing_Tier3_Icon_Virtuous_5", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 18: ["Artificing_Tier3_Pactblade_Temptation_5", "Artificing_Tier3_Icon_Virtuous_5", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 19: ["Artificing_Tier3_Pactblade_Temptation_5", "Artificing_Tier3_Icon_Virtuous_5", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], //19:["Virtuous Icon +5","Upgrade Engraver","Upgrade Carver","Hire an additional Carver"], 20: ["Artificing_Tier3_Pactblade_Temptation_5", "Artificing_Tier3_Icon_Virtuous_5", "Artificing_Tier3_Refine_Basic", "Artificing_Tier2_Refine_Basic", "Artificing_Tier1_Gather_Basic"], 21: ["Artificing_Tier4_Gather_Basic"], 22: ["Artificing_Tier4_Gather_Basic"], 23: ["Artificing_Tier4_Gather_Basic"], 24: ["Artificing_Tier4_Gather_Basic"], 25: ["Artificing_Tier4_Refine_Basic", "Artificing_Tier4_Gather_Basic"], }, }] }; addProfile("Artificing", { profileName: "Surplus Equipment", isProfileActive: true, level: { 23: ["Artificing_Voucher_Gear_T4", "Artificing_Voucher_Gear_T3", "Artificing_Voucher_Gear_T2", "Artificing_Voucher_Gear_T1", "Artificing_Tier4_Gather_Basic"], 24: ["Artificing_Voucher_Gear_T4", "Artificing_Voucher_Gear_T3", "Artificing_Voucher_Gear_T2", "Artificing_Voucher_Gear_T1", "Artificing_Tier4_Gather_Basic"], 25: ["Artificing_Voucher_Gear_T4", "Artificing_Voucher_Gear_T3", "Artificing_Voucher_Gear_T2", "Artificing_Voucher_Gear_T1", "Artificing_Tier4_Refine_Basic", "Artificing_Tier4_Gather_Basic"], } }); addProfile("Artificing", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Artificing_Tier0_Intro_1"], 1: ["Artificing_Tier1_Refine_Basic_Mass", "Artificing_Tier1_Gather_Basic"], 2: "+25", 7: ["Artificing_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Artificing_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Artificing_Tier4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Artificing", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Artificing_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Weaponsmithing"] = { taskListName: "Weaponsmithing", taskName: "Weaponsmithing", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Weaponsmithing_Tier0_Intro"], 1: ["Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 2: ["Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 3: ["Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 4: ["Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 5: ["Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 6: ["Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 7: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 8: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 9: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 10: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 11: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 12: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 13: ["Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 14: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 15: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 16: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 17: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 18: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 19: ["Weaponsmithing_Tier3_Dagger_4", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], 20: ["Weaponsmithing_Tier3_Dagger_Set_2", "Weaponsmithing_Tier2_Dagger_3", "Weaponsmithing_Tier1_Dagger_2", "Weaponsmithing_Tier1_Dagger_1", "Weaponsmithing_Tier1_Gather_Basic"], //19:["Dagger+4","Upgrade Grinder","Upgrade Smelter","Hire an additional Smelter"], 21: ["Weaponsmithing_Tier4_Gather_Basic"], 22: ["Weaponsmithing_Tier4_Gather_Basic"], 23: ["Weaponsmithing_Tier4_Gather_Basic"], 24: ["Weaponsmithing_Tier4_Gather_Basic"], 25: ["Weaponsmithing_Tier4_Refine_Basic", "Weaponsmithing_Tier4_Gather_Basic"], }, }] }; addProfile("Weaponsmithing", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 0: ["Weaponsmithing_Tier0_Intro"], 1: ["Weaponsmithing_Tier1_Refine_Basic_Mass", "Weaponsmithing_Tier1_Gather_Basic"], 2: "+25", 7: ["Weaponsmithing_Tier2_Refine_Basic_Mass"], 8: "+25", 14: ["Weaponsmithing_Tier3_Refine_Basic_Mass"], 15: "+25", 21: ["Weaponsmithing_Tier4_Refine_Basic_Mass"], 22: "+25", }, }); addProfile("Weaponsmithing", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Weaponsmithing_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["Alchemy"] = { taskListName: "Alchemy", taskName: "Alchemy", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "default", isProfileActive: true, level: { 0: ["Alchemy_Tier0_Intro_1"], 1: ["Alchemy_Tier1_Experiment_Rank2", "Alchemy_Tier1_Experimentation_Rank1", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 2: ["Alchemy_Tier1_Experiment_Rank3", "Alchemy_Tier1_Experimentation_Rank2", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 3: ["Alchemy_Tier1_Experiment_Rank4", "Alchemy_Tier1_Experimentation_Rank3", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 4: ["Alchemy_Tier1_Experiment_Rank5", "Alchemy_Tier1_Experimentation_Rank4", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 5: ["Alchemy_Tier1_Experiment_Rank6", "Alchemy_Tier1_Experimentation_Rank5", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 6: ["Alchemy_Tier1_Experiment_Rank7", "Alchemy_Tier1_Experimentation_Rank6", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 7: ["Alchemy_Tier2_Experiment_Rank08", "Alchemy_Tier2_Experimentation_Rank07", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 8: ["Alchemy_Tier2_Experiment_Rank09", "Alchemy_Tier2_Experimentation_Rank08", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 9: ["Alchemy_Tier2_Experiment_Rank10", "Alchemy_Tier2_Experimentation_Rank09", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 10: ["Alchemy_Tier2_Experiment_Rank11", "Alchemy_Tier2_Experimentation_Rank10", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 11: ["Alchemy_Tier2_Experiment_Rank12", "Alchemy_Tier2_Experimentation_Rank11", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 12: ["Alchemy_Tier2_Experiment_Rank13", "Alchemy_Tier2_Experimentation_Rank12", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 13: ["Alchemy_Tier2_Experiment_Rank14", "Alchemy_Tier2_Experimentation_Rank13", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier1_Refine_Basic", "Alchemy_Tier2_Gather_Basic"], 14: ["Alchemy_Tier3_Experiment_Rank15", "Alchemy_Tier3_Experimentation_Rank14", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 15: ["Alchemy_Tier3_Experiment_Rank16", "Alchemy_Tier3_Experimentation_Rank15", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 16: ["Alchemy_Tier3_Experiment_Rank17", "Alchemy_Tier3_Experimentation_Rank16", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 17: ["Alchemy_Tier3_Experiment_Rank18", "Alchemy_Tier3_Experimentation_Rank17", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 18: ["Alchemy_Tier3_Experiment_Rank19", "Alchemy_Tier3_Experimentation_Rank18", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 19: ["Alchemy_Tier3_Experiment_Rank20", "Alchemy_Tier3_Experimentation_Rank19", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier2_Refine_Basic", "Alchemy_Tier1_Refine_Special", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Basic"], 20: ["Alchemy_Tier3_Experiment_Rank21", "Alchemy_Tier3_Experimentation_Rank20", "Alchemy_Tier2_Aquaregia", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier4_Gather_Basic"], 21: ["Alchemy_Tier4_Experiment_Rank22", "Alchemy_Tier4_Experimentation_Rank21", "Alchemy_Tier2_Aquaregia", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier4_Gather_Basic"], 22: ["Alchemy_Tier4_Experiment_Rank23", "Alchemy_Tier4_Experimentation_Rank22", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier1_Gather_Components"], 23: ["Alchemy_Tier4_Experiment_Rank24", "Alchemy_Tier4_Experimentation_Rank23", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier1_Gather_Components"], 24: ["Alchemy_Tier4_Experiment_Rank25", "Alchemy_Tier4_Experimentation_Rank24", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier1_Gather_Components"], 25: ["Alchemy_Tier4_Experimentation_Rank25", "Alchemy_Tier4_Create_Elemental_Unified", "Alchemy_Tier4_Create_Elemental_Aggregate", "Alchemy_Tier3_Protection_Potion_Major", "Alchemy_Tier3_Potency_Potion_Major", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier1_Gather_Components"], }, }] }; addProfile("Alchemy", { profileName: "mass refining", isProfileActive: true, useMassTask: true, level: { 2: ["Alchemy_Tier1_Refine_Basic_Mass", "Alchemy_Tier1_Gather_Basic_Mass"], 3: "+25", 7: ["Alchemy_Tier2_Refine_Basic_Mass", "Alchemy_Tier2_Gather_Components_Mass"], 8: "+25", 14: ["Alchemy_Tier3_Refine_Basic_Mass", "Alchemy_Tier3_Gather_Components_Mass"], 15: "+25", 21: ["Alchemy_Tier4_Refine_Basic_Mass", "Alchemy_Tier4_Gather_Components_Mass"], 22: "+25", }, }); addProfile("Alchemy", { profileName: "Batch of Minor Potions (Rank 3 result)", level: { 3: [ "Alchemy_Tier1_Accuracy_Potion_Minor_Mass", // Batch of Minor Elixir of Accuracy Rare "Alchemy_Tier1_Reflexes_Potion_Minor_Mass", // Batch of Minor Elixirs of Reflexes Rare "Alchemy_Tier1_Force_Potion_Minor_Mass", // Batch of Minor Force Potions "Alchemy_Tier1_Fortification_Potion_Minor_Mass", // Batch of Minor Fortification Potions // "Alchemy_Tier1_Healing_Potion_Minor_Mass", // Batch of Minor Healing Potions "Alchemy_Tier1_Rejuvenation_Potion_Minor_Mass", // Batch of Minor Rejuvenation Potions "Alchemy_Tier1_Tidespan_Potion_Minor_Mass" // Batch of Minor Tidespan Potions ], 4: '+25', } }); addProfile("Alchemy", { profileName: "Elemental Aggregate", level: { 24: ["Alchemy_Tier4_Create_Elemental_Aggregate", "Alchemy_Tier4_Experiment_Rank25", "Alchemy_Tier4_Experimentation_Rank24", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components", "Alchemy_Tier1_Gather_Components"], 25: '+25', } }); addProfile("Alchemy", { profileName: "Aqua Regia", level: { 20: ["Alchemy_Tier2_Aquaregia", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], 21: "+25", 22: ["Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], 23: "+25", } }); addProfile("Alchemy", { profileName: "Aqua Vitae", level: { 20: ["Alchemy_Tier2_Aquavitae_2", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], 21: "+25", } }); addProfile("Alchemy", { profileName: "Protection Superior", level: { 25: ["Alchemy_Tier4_Experimentation_Rank25", "Alchemy_Tier4_Protection_Potion_Superior", "Alchemy_Tier4_Create_Elemental_Aggregate", "Alchemy_Tier3_Protection_Potion_Major", "Alchemy_Tier2_Aquaregia", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], } }); addProfile("Alchemy", { profileName: "Potency Superior", level: { 25: ["Alchemy_Tier4_Experimentation_Rank25", "Alchemy_Tier4_Potency_Potion_Superior", "Alchemy_Tier4_Aquaregia_2", "Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], } }); addProfile("Alchemy", { profileName: "Distilled Potion of Superior Healing", level: { 24: ["Alchemy_Tier4_Healing_Potion_Superior_Distilled"], 25: ["Alchemy_Tier4_Healing_Potion_Superior_Distilled"], } }); addProfile("Alchemy", { profileName: "Blue & Green Vitriol", isProfileActive: true, level: { 1: ["Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"], 2: "+25", }, }); addProfile("Alchemy", { profileName: "Silver & Yellow Vitriol", isProfileActive: true, level: { 7: ["Alchemy_Tier2_Refine_Basic", "Alchemy_Tier2_Gather_Components"], 8: "+25", }, }); addProfile("Alchemy", { profileName: "Red & Emerald Vitriol", isProfileActive: true, level: { 14: ["Alchemy_Tier3_Refine_Basic", "Alchemy_Tier3_Gather_Components"], 15: "+25", }, }); addProfile("Alchemy", { profileName: "Orange & Purple Vitriol", isProfileActive: true, level: { 21: ["Alchemy_Tier4_Refine_Basic", "Alchemy_Tier4_Gather_Components"], 22: "+25", }, }); addProfile("Alchemy", { profileName: "Mass Blue & Green Vitriol", isProfileActive: true, useMassTask: true, level: { 2: ["Alchemy_Tier1_Refine_Basic_Mass", "Alchemy_Tier1_Gather_Basic_Mass"], 3: "+25", }, }); addProfile("Alchemy", { profileName: "Mass Silver & Yellow Vitriol", isProfileActive: true, useMassTask: true, level: { 7: ["Alchemy_Tier2_Refine_Basic_Mass", "Alchemy_Tier2_Gather_Components_Mass"], 8: "+25", }, }); addProfile("Alchemy", { profileName: "Mass Red & Emerald Vitriol", isProfileActive: true, useMassTask: true, level: { 14: ["Alchemy_Tier3_Refine_Basic_Mass", "Alchemy_Tier3_Gather_Components_Mass"], 15: "+25", }, }); addProfile("Alchemy", { profileName: "Mass Orange & Purple Vitriol", isProfileActive: true, useMassTask: true, level: { 21: ["Alchemy_Tier4_Refine_Basic_Mass", "Alchemy_Tier4_Gather_Components_Mass"], 22: "+25", }, }); addProfile("Alchemy", { profileName: "Wondrous Sprocket", isProfileActive: true, level: { 6: ["Alchemy_Tier1_Event_Gond"], 7: "+25", }, }); definedTask["SummerEvent"] = { taskListName: "SummerEvent", taskName: "SummerEvent", taskDefaultPriority: 1, taskDefaultSlotNum: 0, taskActive: true, taskDescription: "", profiles: [{ profileName: "Altars", isProfileActive: true, level: { 0:["Event_Summer_Tier0_Intro"], 1:["Event_Summer_Tier1_Rankup","Event_Summer_Tier1_Caprese","Event_Summer_Tier1_Cornchowder","Event_Summer_Tier1_Watermelonsorbet"], 2:["Event_Summer_Tier2_Rankup","Event_Summer_Tier2_Summerfeast", "Event_Summer_Tier2_Partypoppers","Event_Summer_Tier2_Fireworks", "Event_Summer_Tier2_Festivalgarblower","Event_Summer_Tier2_Festivalgarbupper", "Event_Summer_Tier2_Festivalgarbhead"], 3:["Event_Summer_Tier3_Sunite_Altar","Event_Summer_Tier3_Festivalgarb_Permanent"], } }] }; // Profession priority list by order var tasklist = [ definedTask["Leadership"], definedTask["Jewelcrafting"], definedTask["Alchemy"], definedTask["Weaponsmithing"], definedTask["Artificing"], definedTask["Mailsmithing"], definedTask["Platesmithing"], definedTask["Leatherworking"], definedTask["Tailoring"], definedTask["Blackice"], definedTask["Winterevent"], definedTask["SiegeEvent"], definedTask["SummerEvent"], ]; var customProfiles = []; // [ { taskName: 'name', baseProfile: 'profileName' / null, profile: JSON.parsed_from_input }, { } ....] var scriptSettings = {}; // Populated at login var loggedAccount = null; var UIaccount = null; var accountSettings = {}; var charSettingsList = []; var charNamesList = []; var charStatisticsList = []; // array of char names with the charStatistics for each char. var defaultCharStatistics = { general: { nextTask: null, lastVisit: null, lastSCAVisit: null, refineCounter: 0, refineCounterReset: Date.now(), diamonds: 0, gold: 0, rad: 0, rBI: 0, BI: 0, refined: [0, 0, 0, 0, 0, 0, 0, 0], refineLimitLeft: 0, bagSlots: 0, emptyBagSlots: 0, resourceSlots: 0, emptyResourceSlots: 0, overflow: 0, activeSlots: 0, celestial: 0, ardent: 0, }, professions: { // Names must match unsafeWindow.client.dataModel.model.ent.main.itemassignmentcategories.categories[n].displayname "Leadership": { level: 0, workersUsed: [], workersUnused: [] }, "Alchemy": { level: 0, workersUsed: [], workersUnused: [] }, "Jewelcrafting": { level: 0, workersUsed: [], workersUnused: [] }, "Weaponsmithing": { level: 0,workersUsed: [], workersUnused: [] }, "Artificing": { level: 0, workersUsed: [], workersUnused: [] }, "Mailsmithing": { level: 0, workersUsed: [], workersUnused: []}, "Platesmithing": { level: 0, workersUsed: [], workersUnused: [] }, "Leatherworking": { level: 0, workersUsed: [], workersUnused: [] }, "Tailoring": { level: 0, workersUsed: [], workersUnused: [] }, "Black Ice Shaping": { level: 0, workersUsed: [], workersUnused: [] }, /* "SummerEvent": { level: 0, workersUsed: [], workersUnused: [] }, "Winter Event": { level: 0, workersUsed: [], workersUnused: [] }, "Siege Event": { level: 0, workersUsed: [], workersUnused: [] }, */ }, tools: { "Awl":{used:[],unused:[]}, "Shears":{used:[],unused:[]}, "Hammer":{used:[],unused:[]}, "Needle":{used:[],unused:[]}, "Bellows":{used:[],unused:[]}, "Bezelpusher":{used:[],unused:[]}, "Mortar":{used:[],unused:[]}, "Anvil":{used:[],unused:[]}, "Grindstone":{used:[],unused:[]}, "Philosophersstone":{used:[],unused:[]}, "Loupe":{used:[],unused:[]}, "Graver":{used:[],unused:[]}, "Crucible":{used:[],unused:[]}, "Tongs":{used:[],unused:[]}, }, trackedResources: [], slotUse: [], }; /* For searching unsafeWindow.client.dataModel.model.ent.main.inventory.assignedslots / unsafeWindow.client.dataModel.model.ent.main.inventory.notassignedslots This needs some design change. */ // The definitions themselves are at the bottom of the script var workerList = workerDefinition(); var toolList = toolListDefinition(); var defaultTrackResources = [{ fname: 'Coalescent Ward (Invocation)', name: 'Fuse_Ward_Coalescent_Invocation', bank: false, unbound: true, btc: true, bta: true }, { fname: 'Preservation Ward (Invocation)', name: 'Fuse_Ward_Preservation_Invocation', bank: false, unbound: true, btc: true, bta: true }, { fname: 'Tome of Experience (Account)', name: 'Item_Potion_Xp_Account', bank: false, unbound: true, btc: true, bta: true }, { fname: 'Dragon Egg', name: 'Crafting_Resource_Dragon_Egg', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Unified Elements', name: 'Crafting_Resource_Elemental_Unified', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Elemental Aggregate', name: 'Crafting_Resource_Elemental_Aggregate', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Residuum', name: 'Crafting_Resource_Residuum', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Aqua Regia', name: 'Crafting_Resource_Aquaregia', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Aqua Vitae', name: 'Crafting_Resource_Aquavitae', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Green Vitriol', name: 'Crafting_Resource_Vitriol_Green', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Blue Vitriol', name: 'Crafting_Resource_Vitriol_Blue', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Silver Vitriol', name: 'Crafting_Resource_Vitriol_Silver', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Yellow Vitriol', name: 'Crafting_Resource_Vitriol_Yellow', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Red Vitriol', name: 'Crafting_Resource_Vitriol_Red', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Emerald Vitriol', name: 'Crafting_Resource_Vitriol_Emerald', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Orange Vitriol', name: 'Crafting_Resource_Vitriol_Orange', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Purple Vitriol', name: 'Crafting_Resource_Vitriol_Purple', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Superior Mark of Potency', name: 'Gem_Upgrade_Resource_R5', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Mark of Potency', name: 'Gem_Upgrade_Resource_R4', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Mark of Power', name: 'Artifact_Upgrade_Resource_R3_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Mark of Stability', name: 'Artifact_Upgrade_Resource_R3_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Mark of Union', name: 'Artifact_Upgrade_Resource_R3_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Resonance Stone', name: 'Artifactgear_Food_R4_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Thaumaturgic Stone', name: 'Gemfood_Stone_R4', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Power Stone', name: 'Artifactfood_R4_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Stability Stone', name: 'Artifactfood_R4_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Greater Union Stone', name: 'Artifactfood_R4_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Black Opal', name: 'Gemfood_R5', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Mark of Potency', name: 'Gem_Upgrade_Resource_R3', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Mark of Power', name: 'Artifact_Upgrade_Resource_R2_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Mark of Stability', name: 'Artifact_Upgrade_Resource_R2_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Mark of Union', name: 'Artifact_Upgrade_Resource_R2_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Resonance Stone', name: 'Artifactgear_Food_R3_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Thaumaturgic Stone', name: 'Gemfood_Stone_R3', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Power Stone', name: 'Artifactfood_R3_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Stability Stone', name: 'Artifactfood_R3_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Union Stone', name: 'Artifactfood_R3_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Flawless Sapphire', name: 'Gemfood_R4', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Aquamarine', name: 'Gemfood_R3', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Mark of Potency', name: 'Gem_Upgrade_Resource_R2', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Mark of Power', name: 'Artifact_Upgrade_Resource_R1_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Mark of Stability', name: 'Artifact_Upgrade_Resource_R1_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Mark of Union', name: 'Artifact_Upgrade_Resource_R1_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Resonance Stone', name: 'Artifactgear_Food_R2_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Thaumaturgic Stone', name: 'Gemfood_Stone_R2', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Power Stone', name: 'Artifactfood_R2_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Stability Stone', name: 'Artifactfood_R2_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Lesser Union Stone', name: 'Artifactfood_R2_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Peridot', name: 'Gemfood_R2', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Minor Resonance Stone', name: 'Artifactgear_Food_R1_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Minor Thaumaturgic Stone', name: 'Gemfood_Stone_R1', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Minor Power Stone', name: 'Artifactfood_R1_A', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Minor Stability Stone', name: 'Artifactfood_R1_B', bank: false, unbound: true, btc: false, bta: false }, { fname: 'Minor Union Stone', name: 'Artifactfood_R1_C', bank: false, unbound: true, btc: false, bta: false }, { fname: 'White Pearl', name: 'Gemfood_R1', bank: false, unbound: true, btc: false, bta: false }, { fname: '*Superior Mark of Potency (Bound)', name: 'Gem_Upgrade_Resource_R5', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Mark of Potency (Bound)', name: 'Gem_Upgrade_Resource_R4', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Mark of Power (Bound)', name: 'Artifact_Upgrade_Resource_R3_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Mark of Stability (Bound)', name: 'Artifact_Upgrade_Resource_R3_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Mark of Union (Bound)', name: 'Artifact_Upgrade_Resource_R3_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Resonance Stone (Bound)', name: 'Artifactgear_Food_R4_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Thaumaturgic Stone (Bound)', name: 'Gemfood_Stone_R4', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Power Stone (Bound)', name: 'Artifactfood_R4_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Stability Stone (Bound)', name: 'Artifactfood_R4_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Greater Union Stone (Bound)', name: 'Artifactfood_R4_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Mark of Potency (Bound)', name: 'Gem_Upgrade_Resource_R3', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Mark of Power (Bound)', name: 'Artifact_Upgrade_Resource_R2_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Mark of Stability (Bound)', name: 'Artifact_Upgrade_Resource_R2_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Mark of Union (Bound)', name: 'Artifact_Upgrade_Resource_R2_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Resonance Stone (Bound)', name: 'Artifactgear_Food_R3_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Thaumaturgic Stone (Bound)', name: 'Gemfood_Stone_R3', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Power Stone (Bound)', name: 'Artifactfood_R3_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Stability Stone (Bound)', name: 'Artifactfood_R3_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Union Stone (Bound)', name: 'Artifactfood_R3_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Mark of Potency (Bound)', name: 'Gem_Upgrade_Resource_R2', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Mark of Power (Bound)', name: 'Artifact_Upgrade_Resource_R1_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Mark of Stability (Bound)', name: 'Artifact_Upgrade_Resource_R1_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Mark of Union (Bound)', name: 'Artifact_Upgrade_Resource_R1_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Resonance Stone (Bound)', name: 'Artifactgear_Food_R2_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Thaumaturgic Stone (Bound)', name: 'Gemfood_Stone_R2', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Power Stone (Bound)', name: 'Artifactfood_R2_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Stability Stone (Bound)', name: 'Artifactfood_R2_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Lesser Union Stone (Bound)', name: 'Artifactfood_R2_C', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Minor Resonance Stone (Bound)', name: 'Artifactgear_Food_R1_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Minor Thaumaturgic Stone (Bound)', name: 'Gemfood_Stone_R1', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Minor Power Stone (Bound)', name: 'Artifactfood_R1_A', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Minor Stability Stone (Bound)', name: 'Artifactfood_R1_B', bank: false, unbound: false, btc: true, bta: true }, { fname: '*Minor Union Stone (Bound)', name: 'Artifactfood_R1_C', bank: false, unbound: false, btc: true, bta: true }, ]; var trackResources; try { trackResources = JSON.parse(GM_getValue("tracked_resources", null)); } catch (e) { trackResources = null; } if (!trackResources) { trackResources = defaultTrackResources; }; var defaultScriptSettings = { general: { saveCharNextTime: true, scriptPaused: false, leadershipMode: false, leadershipSound: 50, language: 'en', scriptDebugMode: false, scriptAutoReload: false, autoLogin: false, autoLoginAccount: "", autoLoginPassword: "", autoReload: false, scriptDelayFactor: 1, maxCollectTaskAttempts: 2, defaultVisitTime: 1*60*60*1000, // 1 hour default unasignedSlotRecheck: 0.5*60*60*1000, // 0.5 hour default leadershipTaskTimeout: 5*60*1000, // 5 minutes default leadershipTaskTimeoutRearm: 1*60*1000, // 1 minutes default } }; // Loading script settings. var tempScriptSettings; try { tempScriptSettings = JSON.parse(GM_getValue("settings__script", "{}")); } catch (e) { tempScriptSettings = null; } if (!tempScriptSettings) { console.warn('Script settings couldn\'t be retrieved, loading defaults.'); tempScriptSettings = {}; }; scriptSettings = $.extend(true, {}, defaultScriptSettings, tempScriptSettings); // Loading custom profiles. try { customProfiles = JSON.parse(GM_getValue("custom_profiles", null)); } catch (e) { customProfiles = null; } if (!customProfiles) { console.warn('Custom profiles couldn\'t be retrieved.'); customProfiles = []; }; customProfiles.forEach(function (cProfile, idx) { addProfile(cProfile.taskName, cProfile.profile, cProfile.baseProfile); }); unsafeWindow.console.log('DebugMode set to: ' + scriptSettings.general.scriptDebugMode); console = scriptSettings.general.scriptDebugMode ? unsafeWindow.console || fouxConsole : fouxConsole; var delay_modifier = parseFloat(scriptSettings.general.scriptDelayFactor); delay.SHORT *= delay_modifier; delay.MEDIUM *= delay_modifier; delay.LONG *= delay_modifier; delay.MINS *= 1; delay.DEFAULT *= delay_modifier; delay.TIMEOUT *= delay_modifier; var defaultAccountSettings = { vendorSettings: { vendorJunk: false, vendorGreenUnidAll: false, vendorBlueUnidAll: false, vendorInvocationBlessingsAll: false, vendorKitsLimit: false, vendorAltarsLimit: false, vendorKitsAll: false, vendorAltarsAll: false, vendorProfResults: false, vendorPots1: false, vendorPots2: false, vendorPots3: false, vendorPots4: false, vendorPots5: false, vendorPots6: false, vendorHealingPots: false, vendorHealingPotsAll: false, vendorEnchR1: false, vendorEnchR2: false, vendorEnchR3: false, vendorEnchR4: false, vendorEnchR5: false, vendorLesserMarks: false, }, professionSettings: { fillOptionals: true, autoPurchaseRes: true, trainAssets: true, //spreadLeadershipAssets: true, stopNotLeadership: 0, stopAlchemyAt3: false, }, generalSettings: { refineAD: true, openRewards: false, openCelestialBox: false, openInvocation: true, openVIP: true, keepOneUnopened: false, runSCA: 'never', SCADailyReset: Date.now() - 24*60*60*1000, }, consolidationSettings: { bankCharName: "", transferRate: 100, consolidate: false, minCharBalance: 0, minToTransfer: 10000, }, }; var defaultCharSettings = { charName: "", general: { active: false, overrideGlobalSettings: false, manualTaskSlots: false, }, vendorSettings: { vendorJunk: false, vendorGreenUnidAll: false, vendorBlueUnidAll: false, vendorInvocationBlessingsAll: false, vendorKitsLimit: false, vendorAltarsLimit: false, vendorKitsAll: false, vendorAltarsAll: false, vendorProfResults: false, vendorPots1: false, vendorPots2: false, vendorPots3: false, vendorPots4: false, vendorPots5: false, vendorPots6: false, vendorHealingPots: false, vendorHealingPotsAll: false, vendorEnchR1: false, vendorEnchR2: false, vendorEnchR3: false, vendorEnchR4: false, vendorEnchR5: false, vendorLesserMarks: false, }, professionSettings: { fillOptionals: true, autoPurchaseRes: true, trainAssets: true, //spreadLeadershipAssets: true, stopNotLeadership: 0, stopAlchemyAt3: false, }, generalSettings: { refineAD: true, openRewards: false, openCelestialBox: false, openInvocation: true, openVIP: true, keepOneUnopened: false, runSCA: 'never', }, consolidationSettings: { consolidate: false, minCharBalance: 0, minToTransfer: 100, }, taskListSettings: {}, taskListSettingsManual: [], }; //Adding taskList defaults. tasklist.forEach(function(task) { var profileNames = []; task.profiles.forEach(function(profile) { if (profile.isProfileActive) profileNames.push({ name: profile.profileName, value: profile.profileName }); }); defaultCharSettings.taskListSettings[task.taskListName] = {}; defaultCharSettings.taskListSettings[task.taskListName].taskSlots = task.taskDefaultSlotNum; defaultCharSettings.taskListSettings[task.taskListName].taskProfile = profileNames[0].value; defaultCharSettings.taskListSettings[task.taskListName].taskPriority = task.taskDefaultPriority; defaultCharSettings.taskListSettings[task.taskListName].stopTaskAtLevel = 0; defaultCharSettings.taskListSettings[task.taskListName].useGond = false; defaultCharSettings.taskListSettings[task.taskListName].optPrio = 0; // optional slots priority 0 = assets, 1 = workers }); for (var i = 0; i < 9; i++) { defaultCharSettings.taskListSettingsManual[i] = {}; defaultCharSettings.taskListSettingsManual[i].Profession = tasklist[0].taskListName; defaultCharSettings.taskListSettingsManual[i].Profile = tasklist[0].profiles[0].profileName; //defaultCharSettings.taskListSettingsManual[i].fillAssets = 0; defaultCharSettings.taskListSettingsManual[i].useGond = false; defaultCharSettings.taskListSettingsManual[i].optPrio = 0; } // Set in UI -> var _optPrioOptions = [{name:"Don\'t fill",value:-1}, {name:'Quality',value:0},{name:'Speed',value:1}, {name:'Auto Lead',value:2}, {name:'Only Workers H->L',value:3}, {name:'Only Workers L->H',value:4}, {name:'Tools Only',value:5}, {name:'Purple',value:6}, {name:'Blue',value:7}, {name:'Green',value:8}, {name:'White',value:9}]; // Usable only after login (return account or char settings, depending on override and match) function getSetting(group, name) { var override = false; if (typeof(charSettingsList[curCharName]) !== undefined && typeof(charSettingsList[curCharName].general) !== undefined) { override = charSettingsList[curCharName].general.overrideGlobalSettings; } else console.warn("overrideGlobalSettings could not been reached." ); if (override) { if (typeof(charSettingsList[curCharName][group]) !== undefined && typeof(charSettingsList[curCharName][group][name]) !== undefined) { return charSettingsList[curCharName][group][name]; } else console.warn("charSetting value could not been reached for " + group + " " + name); } if (typeof(accountSettings[group]) !== undefined && typeof(accountSettings[group][name]) !== undefined) { return accountSettings[group][name]; } else console.warn("accountSettings value could not been reached for " + group + " " + name); return null; } var defaultVisitTimeOpts = []; defaultVisitTimeOpts.push({ name: 'none', value: 0}); for (var i = 1; i <= 24; i++) defaultVisitTimeOpts.push({ name: i, value: i*60*60*1000}); // UI Settings var settingnames = [ //{scope: 'script', group: 'general', name: 'scriptPaused', title: 'Pause Script', type: 'checkbox', pane: 'main', tooltip: 'Disable All Automation'}, {scope: 'script', group: 'general', name: 'language', title: tr('settings.main.language'), type: 'select', pane: 'main', tooltip: tr('settings.main.language.tooltip'), opts: [ { name: 'english', value: 'en'}, { name: 'polski', value: 'pl'}, { name: 'français', value: 'fr'}], onchange : function(newValue) { GM_setValue('language', newValue); } }, {scope: 'script', group: 'general', name: 'scriptDebugMode', title: tr('settings.main.debug'), type: 'checkbox', pane: 'main', tooltip: tr('settings.main.debug.tooltip'), onchange: function(newValue) { unsafeWindow.console.log('DebugMode set to: ' + newValue); console = newValue ? unsafeWindow.console || fouxConsole : fouxConsole; } }, {scope: 'script', group: 'general', name: 'autoReload', title: tr('settings.main.autoreload'), type: 'checkbox', pane: 'main', tooltip: tr('settings.main.autoreload.tooltip')}, {scope: 'script', group: 'general', name: 'scriptDelayFactor', title: tr('settings.main.incdelay'), type: 'select', pane: 'main', tooltip: tr('settings.main.incdelay.tooltip'), opts: [ { name: 'default - 1', value: '1'}, { name: '1.5', value: '1.5'}, { name: '2', value: '2'}, { name: '2.5', value: '2.5'}, { name: '3', value: '3'}], }, {scope: 'script', group: 'general', name: 'autoLogin', title: tr('settings.main.autologin'), type: 'checkbox', pane: 'main', tooltip: tr('settings.main.autologin.tooltip')}, {scope: 'script', group: 'general', name: 'autoLoginAccount', title: tr('settings.main.nw_username'), type: 'text', pane: 'main', tooltip: tr('settings.main.nw_username.tooltip')}, {scope: 'script', group: 'general', name: 'autoLoginPassword', title: tr('settings.main.nw_password'), type: 'password', pane: 'main', tooltip: tr('settings.main.nw_password.tooltip')}, {scope: 'script', group: 'general', name: 'saveCharNextTime', title: tr('settings.main.savenexttime'), type: 'checkbox', pane: 'main', tooltip: tr('settings.main.savenexttime.tooltip')}, {scope: 'script', group: 'general', name: 'maxCollectTaskAttempts', title: 'Number of attempts to collect task result', type: 'select', pane: 'main', tooltip: 'After this number of attempts the the script will continue without collecting', opts: [ { name: '1', value: 1}, { name: '2', value: 2}, { name: '3', value: 3}], }, {scope: 'script', group: 'general', name: 'defaultVisitTime', title: 'Default process re-process time for all empty slots (in hours)', type: 'select', pane: 'main', tooltip: 'Default process re-process time for all empty slots', opts: defaultVisitTimeOpts, }, {scope: 'script', group: 'general', name: 'unasignedSlotRecheck', title: 'Recheck unasigned slots every: (in hours)', type: 'select', pane: 'main', tooltip: 'If the char has unasigned slot the script will recheck if the user set it manually', opts: [ { name: "don\'t check", value: 0}, { name: '0.5', value: 0.5*60*60*1000}, { name: '1', value: 1*60*60*1000}, { name: '2', value: 2*60*60*1000}, { name: '3', value: 3*60*60*1000}, { name: '4', value: 4*60*60*1000}], }, {scope: 'script', group: 'general', name: 'leadershipTaskTimeout', title: 'Timeout in manual leadership mode (in minutes)', type: 'select', pane: 'manual', tooltip: 'In manual leadership mode the script will wait this long for you to manually assign a leadership task', opts: [ { name: '1', value: 1*60*1000}, { name: '5', value: 5*60*1000}, { name: '10', value: 10*60*1000}], }, {scope: 'script', group: 'general', name: 'leadershipTaskTimeoutRearm', title: 'Re-arm time in manual leadership mode (in minutes)', type: 'select', pane: 'manual', tooltip: 'After a timeout in manual leadership mode the script will do non-leadership tasks for this long', opts: [ { name: '1', value: 1*60*1000}, { name: '1.5', value: 1.5*60*1000}, { name: '2', value: 2*60*1000}], }, {scope: 'script', group: 'general', name: 'leadershipSound', title: 'Volume of notification in manual leadership mode', type: 'select', pane: 'manual', tooltip: 'Volume of the sound to be played', opts: [ { name: 'off', value: 0}, { name: 'very soft', value: 12}, { name: 'soft', value: 25}, { name: 'medium', value: 50}, { name: 'loud', value: 75}, { name: 'full', value: 100} ], }, {scope: 'account', group: 'generalSettings', name: 'openRewards', title: tr('settings.general.openrewards'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openrewards.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'openCelestialBox', title: tr('settings.general.opencelestial'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.opencelestial.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'keepOneUnopened', title: tr('settings.general.keepOneUnopened'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.keepOneUnopened.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'openInvocation', title: tr('settings.general.openInvocation'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openInvocation.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'openVIP', title: tr('settings.general.openVIP'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openVIP.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'refineAD', title: tr('settings.general.refinead'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.refinead.tooltip')}, {scope: 'account', group: 'generalSettings', name: 'runSCA', title: tr('settings.general.runSCA'), type: 'select', pane: 'main', tooltip: tr('settings.general.runSCA.tooltip'), opts: [ { name: 'never', value: 'never'}, { name: 'free time', value: 'free'}, { name: 'always', value: 'always'}], }, {scope: 'account', group: 'professionSettings', name: 'fillOptionals', type: 'checkbox', pane: 'prof', title: tr('settings.profession.fillOptionals'), tooltip: tr('settings.profession.fillOptionals.tooltip')}, {scope: 'account', group: 'professionSettings', name: 'autoPurchaseRes', type: 'checkbox', pane: 'prof', title: tr('settings.profession.autoPurchase'), tooltip: tr('settings.profession.autoPurchase.tooltip')}, {scope: 'account', group: 'professionSettings', name: 'trainAssets', type:'checkbox', pane: 'prof', title: tr('settings.profession.trainAssets'), tooltip: tr('settings.profession.trainAssets.tooltip')}, //{scope: 'account', group: 'professionSettings', name: 'spreadLeadershipAssets', type:'checkbox', pane: 'prof', title: tr('settings.profession.spreadLeadership'), tooltip: tr('settings.profession.spreadLeadership.tooltip')}, {scope: 'account', group: 'professionSettings', name: 'stopNotLeadership', type:'select', pane: 'prof', title: tr('settings.profession.stopNotLeadership'), tooltip: tr('settings.profession.stopNotLeadership.tooltip'), opts:[{name:'never',value:'0'},{name: '20' ,value: 20},{name: '25' ,value: 25}]}, {scope: 'account', group: 'professionSettings', name: 'stopAlchemyAt3', type:'checkbox', pane: 'prof', title: tr('settings.profession.stopAlchemyAt3'), tooltip: tr('settings.profession.stopAlchemyAt3.tooltip')}, {scope: 'account', group: 'vendorSettings', name:'vendorJunk', type:'checkbox', pane:'vend', title:'Vendor junk..', tooltip:'Vendor all junk items (currently) winterfest fireworks+lanterns'}, {scope: 'account', group: 'vendorSettings', name:'vendorGreenUnidAll', type:'checkbox', pane:'vend', title:'Vendor All Green Unidentified Items', tooltip:'Vendor all green unidentified items'}, {scope: 'account', group: 'vendorSettings', name:'vendorBlueUnidAll', type:'checkbox', pane:'vend', title:'Vendor All Blue Unidentified Items', tooltip:'Vendor all blue unidentified items'}, {scope: 'account', group: 'vendorSettings', name:'vendorInvocationBlessingsAll', type:'checkbox', pane:'vend', title:'Vendor All Invocation Blessings', tooltip:'Vendor all Invocation Blessings'}, {scope: 'account', group: 'vendorSettings', name:'vendorKitsLimit', type:'checkbox', pane:'vend', title:'Vendor/Maintain Node Kit Stacks', tooltip:'Limit skill kits stacks to 50, vendor kits unusable by class, remove all if player has one bag or full bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorAltarsLimit', type:'checkbox', pane:'vend', title:'Vendor/Maintain Altar Stacks', tooltip:'Limit Altars to 80,remove all if player has one bag or full bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorKitsAll', type:'checkbox', pane:'vend', title:'Vendor All Node Kits', tooltip:'Sell ALL skill kits.'}, {scope: 'account', group: 'vendorSettings', name:'vendorAltarsAll', type:'checkbox', pane:'vend', title:'Vendor All Altar', tooltip:'Sell ALL Altars.'}, {scope: 'account', group: 'vendorSettings', name:'vendorProfResults',type:'checkbox',pane:'vend', title:'Vendor/Maintain Prof Crafted Levelup Items', tooltip:'Vendor off Tier 1 to 5 items produced and reused for leveling crafting professions.'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots1', type:'checkbox', pane:'vend', title:'Vendor minor potions (lvl 1)', tooltip:'Vendor all minor potions (lvl 1) found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots2', type:'checkbox', pane:'vend', title:'Vendor lesser potions (lvl 15)',tooltip:'Vendor all lesser potions (lvl 15) found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots3', type:'checkbox', pane:'vend', title:'Vendor potions (lvl 30)', tooltip:'Vendor all potions (lvl 30) found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots4', type:'checkbox', pane:'vend', title:'Vendor greater potions (lvl 45)', tooltip:'Vendor all greater potions (lvl 45) found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots5', type:'checkbox', pane:'vend', title:'Vendor major potions (lvl 60)', tooltip:'Vendor major potions (lvl 60)'}, {scope: 'account', group: 'vendorSettings', name:'vendorPots6', type:'checkbox', pane:'vend', title:'Vendor superior potions (lvl 70)', tooltip:'Vendor superior potions (lvl 70)'}, {scope: 'account', group: 'vendorSettings', name:'vendorHealingPots', type:'checkbox', pane:'vend', title:'Vendor Healing Potions (1-60)', tooltip:'Vendor healing potions (lvl 60)'}, {scope: 'account', group: 'vendorSettings', name:'vendorHealingPotsAll', type:'checkbox', pane:'vend', title:'Vendor All Healing Potions', tooltip:'Vendor all healing potions'}, {scope: 'account', group: 'vendorSettings', name:'vendorEnchR1', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 1', tooltip:'Vendor all Rank 1 enchantments & runestones found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorEnchR2', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 2', tooltip:'Vendor all Rank 2 enchantments & runestones found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorEnchR3', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 3', tooltip:'Vendor all Rank 3 enchantments & runestones found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorEnchR4', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 4', tooltip:'Vendor all Rank 4 enchantments & runestones found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorEnchR5', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 5', tooltip:'Vendor all Rank 5 enchantments & runestones found in player bags'}, {scope: 'account', group: 'vendorSettings', name:'vendorLesserMarks', type:'checkbox', pane:'vend', title:'Vendor Lesser Marks', tooltip:'Vendor all Lesser Marks found in player bags'}, {scope: 'account', group: 'consolidationSettings', name:'consolidate', type:'checkbox', pane:'bank', title: tr('settings.consolid.consolidate'), tooltip: tr('settings.consolid.consolidate.tooltip') ,border:true}, {scope: 'account', group: 'consolidationSettings', name:'bankCharName', type:'text', pane:'bank', title: tr('settings.consolid.bankerName'), tooltip: tr('settings.consolid.bankerName.tooltip')}, {scope: 'account', group: 'consolidationSettings', name:'minToTransfer', type:'text', pane:'bank', title: tr('settings.consolid.minToTransfer'), tooltip: tr('settings.consolid.minToTransfer.tooltip')}, {scope: 'account', group: 'consolidationSettings', name:'minCharBalance', type:'text', pane:'bank', title: tr('settings.consolid.minCharBalance'), tooltip: tr('settings.consolid.minCharBalance.tooltip')}, {scope: 'account', group: 'consolidationSettings', name:'transferRate', type:'text', pane:'bank', title: tr('settings.consolid.transferRate'), tooltip: tr('settings.consolid.transferRate.tooltip')}, {scope: 'char', group: 'general', name: 'active', type:'checkbox', pane: 'main_not_tab', title: 'Active', tooltip: 'The char will be processed by the script', onchange: function(newValue, elm) { if (newValue) { $(elm).parents('.ui-accordion-content').prev().removeClass('inactive'); } else { $(elm).parents('.ui-accordion-content').prev().addClass('inactive'); } } }, {scope: 'char', group: 'general', name:'overrideGlobalSettings', type:'checkbox', pane:'main_not_tab', title:'Override account settings for this char', tooltip:''}, {scope: 'char', group: 'general', name:'manualTaskSlots', type:'checkbox', pane:'main_not_tab', title:'Use per-slot task allocation tab', tooltip:'Per slot profile allocation'}, {scope: 'char', group: 'generalSettings', name: 'openRewards', title: tr('settings.general.openrewards'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openrewards.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'openCelestialBox', title: tr('settings.general.opencelestial'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.opencelestial.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'keepOneUnopened', title: tr('settings.general.keepOneUnopened'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.keepOneUnopened.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'openInvocation', title: tr('settings.general.openInvocation'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openInvocation.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'openVIP', title: tr('settings.general.openVIP'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.openVIP.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'refineAD', title: tr('settings.general.refinead'), type: 'checkbox', pane: 'main', tooltip: tr('settings.general.refinead.tooltip')}, {scope: 'char', group: 'generalSettings', name: 'runSCA', title: tr('settings.general.runSCA'), type: 'select', pane: 'main', tooltip: tr('settings.general.runSCA.tooltip'), opts: [ { name: 'never', value: 'never'}, { name: 'free time', value: 'free'}, { name: 'always', value: 'always'}], }, {scope: 'char', group: 'professionSettings', name: 'fillOptionals', type: 'checkbox', pane: 'prof', title: tr('settings.profession.fillOptionals'), tooltip: tr('settings.profession.fillOptionals.tooltip')}, {scope: 'char', group: 'professionSettings', name: 'autoPurchaseRes', type: 'checkbox', pane: 'prof', title: tr('settings.profession.autoPurchase'), tooltip: tr('settings.profession.autoPurchase.tooltip')}, {scope: 'char', group: 'professionSettings', name: 'trainAssets', type:'checkbox', pane: 'prof', title: tr('settings.profession.trainAssets'), tooltip: tr('settings.profession.trainAssets.tooltip')}, //{scope: 'char', group: 'professionSettings', name: 'spreadLeadershipAssets', type:'checkbox', pane: 'prof', title: tr('settings.profession.spreadLeadership'), tooltip: tr('settings.profession.spreadLeadership.tooltip')}, {scope: 'char', group: 'professionSettings', name: 'stopNotLeadership', type:'select', pane: 'prof', title: tr('settings.profession.stopNotLeadership'), tooltip: tr('settings.profession.stopNotLeadership.tooltip'), opts:[{name:'never',value:0},{name: '20' ,value: 20},{name: '25' ,value: 25}]}, {scope: 'char', group: 'professionSettings', name: 'stopAlchemyAt3', type:'checkbox', pane: 'prof', title: tr('settings.profession.stopAlchemyAt3'), tooltip: tr('settings.profession.stopAlchemyAt3.tooltip')}, {scope: 'char', group: 'vendorSettings', name:'vendorJunk', type:'checkbox', pane:'vend', title:'Vendor junk..', tooltip:'Vendor all junk items (currently) winterfest fireworks+lanterns'}, {scope: 'char', group: 'vendorSettings', name:'vendorGreenUnidAll', type:'checkbox', pane:'vend', title:'Vendor All Green Unidentified Items', tooltip:'Vendor all green unidentified items'}, {scope: 'char', group: 'vendorSettings', name:'vendorBlueUnidAll', type:'checkbox', pane:'vend', title:'Vendor All Blue Unidentified Items', tooltip:'Vendor all blue unidentified items'}, {scope: 'char', group: 'vendorSettings', name:'vendorInvocationBlessingsAll', type:'checkbox', pane:'vend', title:'Vendor All Invocation Blessings', tooltip:'Vendor All Invocation Blessings'}, {scope: 'char', group: 'vendorSettings', name:'vendorKitsLimit', type:'checkbox', pane:'vend', title:'Vendor/Maintain Node Kit Stacks', tooltip:'Limit skill kits stacks to 50, vendor kits unusable by class, remove all if player has one bag or full bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorAltarsLimit', type:'checkbox', pane:'vend', title:'Vendor/Maintain Altar Stacks', tooltip:'Limit Altars to 80,remove all if player has one bag or full bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorKitsAll', type:'checkbox', pane:'vend', title:'Vendor All Node Kits', tooltip:'Sell ALL skill kits.'}, {scope: 'char', group: 'vendorSettings', name:'vendorAltarsAll', type:'checkbox', pane:'vend', title:'Vendor All Altar', tooltip:'Sell ALL Altars.'}, {scope: 'char', group: 'vendorSettings', name:'vendorProfResults',type:'checkbox',pane:'vend', title:'Vendor/Maintain Prof Crafted Levelup Items', tooltip:'Vendor off Tier 1 to 5 items produced and reused for leveling crafting professions.'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots1', type:'checkbox', pane:'vend', title:'Vendor minor potions (lvl 1)', tooltip:'Vendor all minor potions (lvl 1) found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots2', type:'checkbox', pane:'vend', title:'Vendor lesser potions (lvl 15)',tooltip:'Vendor all lesser potions (lvl 15) found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots3', type:'checkbox', pane:'vend', title:'Vendor potions (lvl 30)', tooltip:'Vendor all potions (lvl 30) found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots4', type:'checkbox', pane:'vend', title:'Vendor greater potions (lvl 45)', tooltip:'Vendor all greater potions (lvl 45) found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots5', type:'checkbox', pane:'vend', title:'Vendor major potions (lvl 60)', tooltip:'Vendor major potions (lvl 60)'}, {scope: 'char', group: 'vendorSettings', name:'vendorPots6', type:'checkbox', pane:'vend', title:'Vendor superior potions (lvl 70)', tooltip:'Vendor superior potions (lvl 70)'}, {scope: 'char', group: 'vendorSettings', name:'vendorHealingPots', type:'checkbox', pane:'vend', title:'Vendor Healing Potions (1-60)', tooltip:'Vendor healing potions (lvl 60)'}, {scope: 'char', group: 'vendorSettings', name:'vendorHealingPotsAll', type:'checkbox', pane:'vend', title:'Vendor All Healing Potions', tooltip:'Vendor all healing potions'}, {scope: 'char', group: 'vendorSettings', name:'vendorEnchR1', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 1', tooltip:'Vendor all Rank 1 enchantments & runestones found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorEnchR2', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 2', tooltip:'Vendor all Rank 2 enchantments & runestones found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorEnchR3', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 3', tooltip:'Vendor all Rank 3 enchantments & runestones found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorEnchR4', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 4', tooltip:'Vendor all Rank 4 enchantments & runestones found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorEnchR5', type:'checkbox', pane:'vend', title:'Vendor enchants & runes Rank 5', tooltip:'Vendor all Rank 5 enchantments & runestones found in player bags'}, {scope: 'char', group: 'vendorSettings', name:'vendorLesserMarks', type:'checkbox', pane:'vend', title:'Vendor Lesser Marks', tooltip:'Vendor all Lesser Marks found in player bags'}, {scope: 'char', group: 'consolidationSettings', name:'consolidate', type:'checkbox', pane:'bank', title: tr('settings.consolid.consolidate'), tooltip: tr('settings.consolid.consolidate.tooltip'), border:true}, {scope: 'char', group: 'consolidationSettings', name:'minToTransfer', type:'text', pane:'bank', title: tr('settings.consolid.minToTransfer'), tooltip: tr('settings.consolid.minToTransfer.tooltip')}, {scope: 'char', group: 'consolidationSettings', name:'minCharBalance', type:'text', pane:'bank', title: tr('settings.consolid.minCharBalance'), tooltip: tr('settings.consolid.minCharBalance.tooltip')}, ]; /* // TODO: fix debug console on save call // call the onsave for the setting if it exists if (typeof(settingnames[i].onsave) === "function") { console.log("Calling 'onsave' for", settingnames[i].name); settingnames[i].onsave(settings[settingnames[i].name], settings[settingnames[i].name]); } } */ // Page Settings var PAGES = Object.freeze({ LOGIN: { name: "Login", path: "div#login" }, GUARD: { name: "Guard", path: "div#page-accountguard" }, }); /** * Uses the page settings to determine which page is currently displayed */ function GetCurrentPage() { var pageReturn; $.each(PAGES, function(index, page) { if ($(page["path"]).filter(":visible").length) { pageReturn = page["name"]; return false; } }); return pageReturn; } /** * Logs in to gateway * No client.dataModel exists at this stage */ function page_LOGIN() { //if (!$("form > p.error:visible").length && settings["autologin"]) { // No previous log in error - attempt to log in if (scriptSettings.general.autoLogin) { console.log("Setting username"); $("input#user").val(scriptSettings.general.autoLoginAccount); console.log("Setting password"); $("input#pass").val(scriptSettings.general.autoLoginPassword); console.log("Clicking Login Button"); $("div#login > input").click(); //} } dfdNextRun.resolve(delay.LONG); } /** * Action to perform on account guard page */ function page_GUARD() { // Do nothing on the guard screen // dfdNextRun.resolve(delay.LONG); PauseSettings("pause"); } /** * Collects rewards for tasks or starts new tasks * Function is called once per new task and returns true if an action is created * If no action is started function returns false to switch characters */ function processCharacter() { // Switch to professions page to show task progression unsafeWindow.location.hash = "#char(" + encodeURI(unsafeWindow.client.getCurrentCharAtName()) + ")/professions"; // Collect rewards for completed tasks and restart if (unsafeWindow.client.dataModel.model.ent.main.itemassignments.complete) { if (!unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.every(function(entry, idx) { if (entry.hascompletedetails && (collectTaskAttempts[idx] < scriptSettings.general.maxCollectTaskAttempts)) { unsafeWindow.client.professionTaskCollectRewards(entry.uassignmentid); collectTaskAttempts[idx]++; return false; } return true; })) { dfdNextRun.resolve(delay.SHORT); return true; } } // Check for available slots and start new task console.log("Looking for empty slots."); var slots = unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.filter(function(entry) { return (!entry.islockedslot && !entry.uassignmentid); }); if (slots.length) { if (charSettingsList[curCharName].general.manualTaskSlots) { var slotIndex = slots[0].slotindex; var _task = tasklist.filter(function(task) { return task.taskListName === charSettingsList[curCharName].taskListSettingsManual[slotIndex].Profession; })[0]; var _profile = _task.profiles.filter(function(profile) { return profile.profileName === charSettingsList[curCharName].taskListSettingsManual[slotIndex].Profile; })[0]; if (failedProfiles[_task.taskListName] && failedProfiles[_task.taskListName].indexOf(_profile.profileName) === -1) { console.warn("Profile ", _profile.profileName, " for task ", _task.taskListName, " failed previously, skipping slot"); return false; // TODO: Should skip the slot and not the char entierly. } console.log("Allocating per slot. For slot #" + slotIndex + " profession: " + _task.taskListName + " profile: " + _profile.profileName); unsafeWindow.client.professionFetchTaskList('craft_' + _task.taskName); var tOptions = { useGond: charSettingsList[curCharName].taskListSettingsManual[slotIndex].useGond, optPrio: charSettingsList[curCharName].taskListSettingsManual[slotIndex].optPrio } window.setTimeout(function() { createNextTask(_task, _profile, 0, tOptions); }, delay.SHORT); return true; } else { // Go through the professions to assign tasks until specified slots filled console.log("Prioritizing task lists."); var charTaskList = tasklist .filter(function(task) { var level = unsafeWindow.client.dataModel.model.ent.main.itemassignmentcategories.categories.filter(function(entry) { return entry.name == task.taskName; }) level = (level[0]) ? level[0].currentrank : 0; console.log(level, task.taskListName, (charSettingsList[curCharName].taskListSettings[task.taskListName].stopTaskAtLevel == 0 || charSettingsList[curCharName].taskListSettings[task.taskListName].stopTaskAtLevel > level)); return ((charSettingsList[curCharName].taskListSettings[task.taskListName].taskSlots > 0) && (failedTasksList.indexOf(task.taskListName) === -1) && (charSettingsList[curCharName].taskListSettings[task.taskListName].stopTaskAtLevel == 0 || charSettingsList[curCharName].taskListSettings[task.taskListName].stopTaskAtLevel > level)); }) .sort(function(a, b) { return (charSettingsList[curCharName].taskListSettings[a.taskListName].taskPriority - charSettingsList[curCharName].taskListSettings[b.taskListName].taskPriority); }); console.log("Attempting to fill the slot."); for (var i = 0; i < charTaskList.length; i++) { var currentTasks = unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.filter(function(entry) { return entry.category == charTaskList[i].taskName; }); if (currentTasks.length < charSettingsList[curCharName].taskListSettings[charTaskList[i].taskListName].taskSlots) { unsafeWindow.client.professionFetchTaskList('craft_' + charTaskList[i].taskName); var profile = charTaskList[i].profiles.filter(function(profile) { return profile.profileName == charSettingsList[curCharName].taskListSettings[charTaskList[i].taskListName].taskProfile; })[0]; console.log('Selecting profile: ' + profile.profileName); if (scriptSettings.general.leadershipMode && charTaskList[i].taskName == 'Leadership') { var olddate = new Date(); olddate.setTime( olddate.getTime() - scriptSettings.general.leadershipTaskTimeoutRearm); if ( !leadershipSlots[curCharName] || leadershipSlots[curCharName] < olddate) { // new slot open for leadership (first time or timer re-armed) var tdate = new Date(); tdate.setTime( tdate.getTime() + parseInt(scriptSettings.general.leadershipTaskTimeout)); leadershipSlots[curCharName] = tdate; var soundFx = $( '#soundFX' ); if (scriptSettings.general.leadershipSound > 0 && soundFx && soundFx[0]) { soundFx[0].volume = scriptSettings.general.leadershipSound / 100; soundFx[0].play(); } } if ( leadershipSlots[curCharName] > new Date() ) { // in waiting console.log('Manual Leadership slot, waiting until: ' + leadershipSlots[curCharName]); chartimers[curCharNum] = getNextFinishedTask(); if (chartimers[curCharNum] > leadershipSlots[curCharName]) { chartimers[curCharNum] = leadershipSlots[curCharName]; } return false; } } else { var tOptions = { useGond: charSettingsList[curCharName].taskListSettings[charTaskList[i].taskListName].useGond, optPrio: charSettingsList[curCharName].taskListSettings[charTaskList[i].taskListName].optPrio } window.setTimeout(function() { createNextTask(charTaskList[i], profile, 0, tOptions); }, delay.SHORT); return true; } } } }; console.log("All task counts assigned"); } else { console.log("No available task slots"); } // TODO: Add code to get next task finish time chartimers[curCharNum] = getNextFinishedTask(); // Add diamond count chardiamonds[curCharNum] = unsafeWindow.client.dataModel.model.ent.main.currencies.diamonds; console.log(curCharName + "'s", "Astral Diamonds:", chardiamonds[curCharNum]); // Add gold count chargold[curCharNum] = parseInt(unsafeWindow.client.dataModel.model.ent.main.currencies.gold); return false; } // Running SCA for a single Char (based on CycleSCA) function processCharSCA(charIdx) { var _hasLoginDaily = 0; var _scaHashMatch = /\/adventures$/; var _charName = charNamesList[charIdx]; var _fullCharName = _charName + "@" + loggedAccount; /* if (!scriptSettings.paused) PauseSettings("pause"); */ if (!_scaHashMatch.test(unsafeWindow.location.hash)) { return; } else if (unsafeWindow.location.hash != "#char(" + encodeURI(_fullCharName) + ")/adventures") { unsafeWindow.location.hash = "#char(" + encodeURI(_fullCharName) + ")/adventures"; } WaitForState("").done(function() { try { _hasLoginDaily = client.dataModel.model.gatewaygamedata.dailies.left.logins; } catch (e) { window.setTimeout(function() { processCharSCA(charIdx); }, delay.SHORT); return; } console.log("Checking SCA Daily for " + _charName ); // Do SCA daily dice roll if the button comes up WaitForState(".daily-dice-intro").done(function() { $(".daily-dice-intro button").trigger('click'); WaitForState(".daily-awards-button").done(function() { $(".daily-awards-button button").trigger('click'); }); }); //console.log("after dice"); WaitForNotState(".modal-window.daily-dice").done(function() { charStatisticsList[_charName].general.lastSCAVisit = Date.now(); GM_setValue("statistics__char__" + _fullCharName , JSON.stringify(charStatisticsList[_charName])); updateCounters(); //Adjusting for the time the SCA took var chardelay; if (chartimers[curCharNum] != null) { chardelay = (chartimers[curCharNum]).getTime() - (new Date()).getTime() - unsafeWindow.client.getServerOffsetSeconds() * 1000; if (chardelay < delay.SHORT) { chardelay = delay.SHORT; } } else chardelay = delay.SHORT; if (chardelay > (delay.SHORT * 3)) unsafeWindow.location.hash = "#char(" + encodeURI(_fullCharName) + ")/professions"; console.log("Finished SCA check for " + charNamesList[charIdx] + " delay " + chardelay); dfdNextRun.resolve(chardelay); }); }); } /** * Switch to a character's swordcoast adventures and collect the daily reward */ function processSwordCoastDailies(_charStartIndex) { var _accountName = unsafeWindow.client.dataModel.model.loginInfo.publicaccountname; var _charIndex = (!_charStartIndex || parseInt(_charStartIndex) > (charNamesList.length + 1) || parseInt(_charStartIndex) < 0) ? 0 : parseInt(_charStartIndex); var _fullCharName = charNamesList[_charIndex] + '@' + _accountName; var _hasLoginDaily = 0; var _isLastChar = false; var _scaHashMatch = /\/adventures$/; if (!scriptSettings.paused) PauseSettings("pause"); // Switch to professions page to show task progression if (!_scaHashMatch.test(unsafeWindow.location.hash)) { return; } else if (unsafeWindow.location.hash != "#char(" + encodeURI(_fullCharName) + ")/adventures") { unsafeWindow.location.hash = "#char(" + encodeURI(_fullCharName) + ")/adventures"; } if (_charIndex >= (charNamesList.length -1)) _isLastChar = true; WaitForState("").done(function() { try { _hasLoginDaily = client.dataModel.model.gatewaygamedata.dailies.left.logins; } catch (e) { // TODO: Use callback function window.setTimeout(function() { processSwordCoastDailies(_charIndex); }, delay.SHORT); return; } console.log("Checking SCA Daily for", _fullCharName, "..."); // Do SCA daily dice roll if the button comes up WaitForState(".daily-dice-intro").done(function() { $(".daily-dice-intro button").trigger('click'); WaitForState(".daily-awards-button").done(function() { $(".daily-awards-button button").trigger('click'); }); }); // If Dice roll dialogue is non existent WaitForNotState(".modal-window.daily-dice").done(function() { charStatisticsList[charNamesList[_charIndex]].general.lastSCAVisit = Date.now(); GM_setValue("statistics__char__" + _fullCharName , JSON.stringify(charStatisticsList[charNamesList[_charIndex]])); updateCounters(); if (_isLastChar) { window.setTimeout(function() { PauseSettings("unpause"); }, 3000); } else { window.setTimeout(function() { processSwordCoastDailies(_charIndex + 1); }, 3000); } }); }); } /** * Finds the task finishing next & returns the date or NULL otherwise * * @return {Date} / {null} */ function getNextFinishedTask() { var tmpNext, next = null; var foundTask = false; unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.forEach(function(entry, idx) { if (entry.uassignmentid && (collectTaskAttempts[idx] < scriptSettings.general.maxCollectTaskAttempts)) { foundTask = true; tmpNext = new Date(entry.ufinishdate); if (!next || tmpNext < next) { next = tmpNext; } } if (!entry.islockedslot && entry.category == "None" && scriptSettings.general.unasignedSlotRecheck) { var tdate = new Date(); tdate.setTime( tdate.getTime() + parseInt(scriptSettings.general.unasignedSlotRecheck)); console.log("Found unassigned slot, setting it as: ", tdate); if (!next || tdate < next) { next = tdate; } } }); if (next && foundTask) { console.log("Next finished task at " + next.toLocaleString()); } else { console.log("No next finishing date found! All slots unassigned."); if (scriptSettings.general.defaultVisitTime) { var tdate = new Date(); tdate.setTime( tdate.getTime() + parseInt(scriptSettings.general.defaultVisitTime)); console.log("Setting next date using default: ", tdate); return tdate; } } return next; } /** * Iterative approach to finding the next task to assign to an open slot. * * @param {Array} prof The tasklist for the profession being used * @param {int} i The current task number being attempted */ function createNextTask(prof, profile, i, addOptions) { // TODO: Use callback function if (!unsafeWindow.client.dataModel.model.craftinglist || unsafeWindow.client.dataModel.model.craftinglist === null || !unsafeWindow.client.dataModel.model.craftinglist['craft_' + prof.taskName] || unsafeWindow.client.dataModel.model.craftinglist['craft_' + prof.taskName] === null) { console.log('Task list not loaded for:', prof.taskName); window.setTimeout(function() { createNextTask(prof, profile, i, addOptions); }, delay.SHORT); return false; } // Check level var category = unsafeWindow.client.dataModel.model.ent.main.itemassignmentcategories.categories.filter(function(entry) { return entry.name == prof.taskName; }); var level = category ? category[0].currentrank : 0; var list = profile.level[level]; var taskBlocked = ((getSetting('professionSettings','stopNotLeadership') == 20 && prof.taskName != 'Leadership' && level >= 20) || (getSetting('professionSettings','stopNotLeadership') == 25 && prof.taskName != 'Leadership' && level >= 25) || (getSetting('professionSettings','stopAlchemyAt3') && prof.taskName == 'Alchemy' && level > 3)) || !category; if(list.length <= i || taskBlocked) { if (!taskBlocked) console.log("Task list exhausted for ", prof.taskListName, " at level ", level, " profile: ", profile.profileName); else console.warn("Task list blocked for ", prof.taskListName, " at level ", level, " profile: ", profile.profileName); failedTasksList.push(prof.taskListName); if (typeof failedProfiles[prof.taskListName] === 'undefined') { failedProfiles[prof.taskListName] = []; } failedProfiles[prof.taskListName].push(profile.profileName); dfdNextRun.resolve(delay.SHORT); // switchChar(); return false; } console.log(prof.taskName, "is level", level); console.log("createNextTask", list.length, i); var taskName = list[i]; console.log("Searching for task:", taskName); // Search for task to start var task = searchForTask(taskName, prof.taskName, profile, level); // Finish createNextTask function if (task === null) { console.log("Skipping task selection to purchase resources"); dfdNextRun.resolve(); return true; } if (task) { antiInfLoopTrap.currTaskName = task.def.name; antiInfLoopTrap.currCharName = unsafeWindow.client.getCurrentCharAtName(); task = '/professions-tasks/' + prof.taskName + '/' + task.def.name; console.log('Task Found'); unsafeWindow.location.hash = unsafeWindow.location.hash.replace(/\)\/.+/, ')' + task); WaitForState("div.page-professions-taskdetails").done(function() { // Click all buttons and select an item to use in the slot var def = $.Deferred(); var buttonList = $('.taskdetails-assets:eq(1)').find("button"); if (buttonList.length && getSetting('professionSettings','fillOptionals') && (parseInt(addOptions["optPrio"]) != -1)) { var _options = { useGond: addOptions["useGond"], optPrio: addOptions["optPrio"] } SelectItemFor(buttonList, 0, def, prof, taskName, prof.taskName, profile, level, _options); } else { def.resolve(); } def.done(function() { // All items are populated console.log("Items Populated"); // Click the Start Task Button //Get the start task button if it is enabled var enabledButton = $(".footer-professions-taskdetails .button.epic:not('.disabled') button"); if (enabledButton.length) { console.log("Clicking Start Task Button"); enabledButton.trigger('click'); WaitForState("").done(function() { // Done dfdNextRun.resolve(delay.SHORT); }); if (antiInfLoopTrap.prevCharName == antiInfLoopTrap.currCharName && antiInfLoopTrap.prevTaskName == antiInfLoopTrap.currTaskName) { antiInfLoopTrap.startCounter++; console.log(antiInfLoopTrap.prevCharName + " starts " + antiInfLoopTrap.prevTaskName + " " + antiInfLoopTrap.startCounter + " time in row"); } else { antiInfLoopTrap.prevCharName = antiInfLoopTrap.currCharName; antiInfLoopTrap.prevTaskName = antiInfLoopTrap.currTaskName; antiInfLoopTrap.startCounter = 1; } if (antiInfLoopTrap.startCounter >= 10) { console.log("Restart needed: " + (antiInfLoopTrap.trapActivation - antiInfLoopTrap.startCounter) + " loop circuits to restart"); } return true; } else { // Button not enabled, something required was probably missing // Go back $(".footer-professions-taskdetails .button button.resetWindow").trigger('click'); WaitForState("").done(function() { // continue with the next one console.log('Finding next task'); createNextTask(prof, profile, i + 1, addOptions); }); } }); }); } else { console.log('Finding next task'); createNextTask(prof, profile, i + 1, addOptions); } } /** Count resouce in bags * * @param {string} name The name of resource */ function countResource(name) { var count = 0; var _bags = unsafeWindow.client.dataModel.model.ent.main.inventory.bags; console.log("Checking bags for " + name); $.each(_bags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot && slot.name === name) { count = count + slot.count; } }); }); return count; } function countUnusedResource(name) { var count = 0; var bag = unsafeWindow.client.dataModel.model.ent.main.inventory.tradebag; bag.forEach(function(slot) { if (slot && slot.name === name) { count = count + slot.count; } }); return count; } function countUsedResource(name) { return countResource(name) - countUnusedResource(name); } /** * Checks task being started for requirements and initiates beginning task if found * * @param {string} taskname The name of the task being started * @param {string} profname The name of the profession being used * @param {Deferred} dfd Deferred object to process on return */ function searchForTask(taskname, profname, profile, professionLevel) { // Return first object that matches exact craft name var thisTask = unsafeWindow.client.dataModel.model.craftinglist['craft_' + profname].entries.filter(function(entry) { return entry.def && entry.def.name == taskname; })[0]; // If no task is returned we either have three of this task already, the task is a rare that doesn't exist currently, or we have the name wrong in tasklist if (!thisTask) { console.log('Could not find task for:', taskname); return false; } // start task if requirements are met if (!thisTask.failslevelrequirementsfilter && !thisTask.failslevelrequirements && !thisTask.failsresourcesrequirements) { return thisTask; } // Too high level if (thisTask.failslevelrequirements) { console.log("Task level is too high:", taskname); return false; } var searchItem = null; var searchAsset = false; // Check for and buy missing armor & weapon leadership assets if (thisTask.failsresourcesrequirements && profname == "Leadership" && getSetting('professionSettings','autoPurchaseRes')) { var failedAssets = thisTask.required.filter(function(entry) { return !entry.fillsrequirements; }); var failedArmor = failedAssets.filter(function(entry) { return entry.categories.indexOf("Armor") >= 0; }); var failedWeapon = failedAssets.filter(function(entry) { return entry.categories.indexOf("Weapon") >= 0; }); if (failedArmor.length || failedWeapon.length) { var _buyResult = false; var _charGold = unsafeWindow.client.dataModel.model.ent.main.currencies.gold; var _charSilver = unsafeWindow.client.dataModel.model.ent.main.currencies.silver; var _charCopper = unsafeWindow.client.dataModel.model.ent.main.currencies.copper; var _charCopperTotal = _charCopper + (_charSilver * 100) + (_charGold * 10000); // Buy Leadership Armor Asset if (failedArmor.length && _charCopperTotal >= 10000) { console.log("Buying leadership asset:", failedArmor[0].icon); _buyResult = buyTaskAsset(18); unsafeWindow.client.professionFetchTaskList("craft_Leadership"); } // Buy Leadership Infantry Weapon Asset else if (failedWeapon.length && _charCopperTotal >= 5000) { console.log("Buying leadership asset:", failedWeapon[0].icon); _buyResult = buyTaskAsset(4); unsafeWindow.client.professionFetchTaskList("craft_Leadership"); } if (_buyResult === false) return false; else return null; } } // Missing assets or ingredients if (thisTask.failsresourcesrequirements) { var failedAssets = thisTask.required.filter(function(entry) { return !entry.fillsrequirements; }); // Missing required assets if (failedAssets.length) { var failedCrafter = failedAssets.filter(function(entry) { return entry.categories.indexOf("Person") >= 0; }); // Train Assets if (failedCrafter.length && getSetting('professionSettings','trainAssets')) { console.log("Found required asset:", failedCrafter[0].icon); searchItem = failedCrafter[0].icon; searchAsset = true; } else { // TODO: Automatically purchase item assets from shop console.log("Not enough assets for task:", taskname); return false; } } // Check for craftable ingredients items and purchasable profession resources (from vendor) else { var failedResources = thisTask.consumables.filter(function(entry) { return entry.required && !entry.fillsrequirements; }); // Check first required ingredient only // If it fails to buy or craft task cannot be completed anyway // If it succeeds script will search for tasks anew var itemName = failedResources[0].hdef.match(/\[(\w+)\]/)[1]; // Buy purchasable resources if auto-purchase setting is enabled if (getSetting('professionSettings','autoPurchaseRes') && itemName.match(/^Crafting_Resource_(Charcoal|Rocksalt|Spool_Thread|Porridge|Solvent|Brimstone|Coal|Moonseasalt|Quicksilver|Spool_Threadsilk)$/)) { // returns null if successful (task will try again) and false if unsuccessful (task will be skipped) return buyResource(itemName); } // Matched profession auto-purchase item found but auto-purchase is not enabled else if (!getSetting('professionSettings','autoPurchaseRes') && itemName.match(/^Crafting_Resource_(Charcoal|Rocksalt|Spool_Thread|Porridge|Solvent|Brimstone|Coal|Moonseasalt|Quicksilver|Spool_Threadsilk)$/)) { console.log("Purchasable resource required:", itemName, "for task:", taskname, ". Recommend enabling Auto Purchase Resources."); if (pleaseBuy.push("Please buy " + itemName + " for " + unsafeWindow.client.getCurrentCharAtName()) > 5) { pleaseBuy.shift(); } return false; } // craftable ingredient set to search for else { console.log("Found required ingredient:", itemName); searchItem = itemName; } } } // either no craftable items/assets found or other task requirements are not met // Skip crafting ingredient tasks for Leadership if (searchItem === null || !searchItem.length || (profname == 'Leadership' && !searchAsset && !searchItem.match(/Crafting_Asset_Craftsman/))) { console.log("Failed to resolve item requirements for task:", taskname); return false; } var massTaskAllowed = ((profile !== undefined) && (profile.useMassTask !== undefined) && (profile.useMassTask === true)); // Generate list of available tasks to search ingredients/assets from console.log("Searching ingredient tasks for:", profname); var taskList = unsafeWindow.client.dataModel.model.craftinglist['craft_' + profname].entries.filter(function(entry) { // remove header lines first to avoid null def if (entry.isheader) { return false; } // Too high level if (entry.failslevelrequirements) { return false; } // Rewards do not contain item we want to make if (searchAsset) { if (entry.def.icon != searchItem || !entry.def.name.match(/Recruit/) || entry.def.requiredrank > 14) { return false; } } else { if (!(entry.rewards.some(function(itm) { try { return itm.hdef.match(/\[(\w+)\]/)[1] == searchItem; } catch (e) {} }))) { return false; } } // Skip mass production tasks (don't skip for profiles with useMassTask flag == true) if (! massTaskAllowed) { if (entry.def.displayname.match(/^(Batch|Mass|Deep|Intensive) /)) { return false; } } // Skip trading tasks if (entry.def.displayname.match(/rading$/)) { return false; } // Skip looping Transmute tasks if (entry.def.displayname.match(/^(Transmute|Create) /)) { return false; } return true; }); if (!taskList.length) { console.log("No ingredient tasks found for:", taskname, searchItem); if (!searchItem.match(/(_Research)|(_Craftsman_)|(Crafted_)/)) { if (pleaseBuy.push("Please buy " + searchItem + " for " + unsafeWindow.client.getCurrentCharAtName()) > 5) { pleaseBuy.shift(); } } return false; } // for profiles with useMassTask flag == true select Mass task if (massTaskAllowed) { for (var i=0; i<taskList.length; i++) { if (taskList[i].def.displayname.match(/^(Batch|Mass|Deep|Intensive) /)) { taskList = taskList.splice(i, 1); break; } } } // Use more efficient Empowered task for Aqua if available. if ((searchItem == "Crafting_Resource_Aquavitae" || searchItem == "Crafting_Resource_Aquaregia") && taskList.length > 1) { taskList.shift(); } // Should really only be one result now but lets iterate through anyway. for (var i = 0; i < taskList.length; i++) { console.log("Attempting search for ingredient task:", taskList[i].def.name); var task = searchForTask(taskList[i].def.name, profname, profile, professionLevel); if (task === null || task) { return task; } } return false; } /** * Selects the highest level asset for the i'th button in the list. Uses an iterative approach * in order to apply a sufficient delay after the asset is assigned * * @param {Array} The list of buttons to use to click and assign assets for * @param {int} i The current iteration number. Will select assets for the i'th button * @param {Deferred} jQuery Deferred object to resolve when all of the assets have been assigned */ function SelectItemFor(buttonListIn, i, def, prof, taskname, profname, profile, professionLevel, options) { buttonListIn[i].click(); WaitForState("").done(function() { console.log("fill optionals options: ", options); var $assets; if (options != null && options["useGond"]) { $assets = $("div.modal-item-list a").has("img[src*='Hammer'],img[src*='_Resource_'],img[src*='_Assets_'],img[src*='_Tools_'],img[src*='_Tool_'],img[src*='_Jewelersloupe_'],img[src*='_Bezelpusher_']"); } else { $assets = $("div.modal-item-list a").has("img[src*='_Resource_'],img[src*='_Assets_'],img[src*='_Tools_'],img[src*='_Tool_'],img[src*='_Jewelersloupe_'],img[src*='_Bezelpusher_']"); } var $persons = $("div.modal-item-list a").has("img[src*='_Follower_']"); var quality = [".Mythic", ".Legendary", ".Special", ".Gold", ".Silver", ".Bronze"]; var ic, $it; var clicked = false; var $select1 = $assets; var $select2 = $persons; // Set in UI -> var _optPrioOptions = [{name:"Don\'t fill",value:-1}, {name:'Quality',value:0},{name:'Speed',value:1}, {name:'Auto Lead',value:2}, {name:'Only Workers H->L',value:3}, {name:'Only Workers L->H',value:4}, {name:'Tools Only',value:5}, {name:'Purple',value:6}, {name:'Blue',value:7}, {name:'Green',value:8}, {name:'White',value:9}]; if (jQuery.isEmptyObject(options)) options["optPrio"] = 0; switch(parseInt(options["optPrio"])) { case 0: $select1 = $assets; $select2 = $persons; break; case 1: $select1 = $persons; $select2 = $assets; break; case 2: $select1 = $assets; $select2 = $persons; if (prof.taskName === "Leadership") { $select1 = $persons; $select2 = $persons; var T3_Epic = 0; var T3_Rare = 0; var T3_Uncommon = 0; unsafeWindow.client.dataModel.model.ent.main.inventory.notassignedslots .forEach(function(item) { if (item.name == "Crafting_Asset_Craftsman_Leadership_T3_Epic") T3_Epic = item.count; // number of heroes not assigneds in inventory if (item.name == "Crafting_Asset_Craftsman_Leadership_T3_Rare") T3_Rare = item.count; // number of adventurers not assigneds in inventory if (item.name == "Crafting_Asset_Craftsman_Leadership_T3_Uncommon") T3_Uncommon = item.count; // number of man-at-arms not assigneds in inventory }); //var usedCommon = countUsedResource("Crafting_Asset_Craftsman_Leadership_T3_Common") + countUsedResource("Crafting_Asset_Craftsman_Leadership_T2_Common") + countUsedResource("Crafting_Asset_Craftsman_Leadership_T1_Common_1"); //number of used mercenaries, guards and footmen var maxAssignedSlots = charSettingsList[curCharName].taskListSettings["Leadership"].taskSlots; var assignedSlots = unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.filter(function(entry) { return entry.category == "Leadership"; }).length; var emptySlotsLeft = unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.filter(function(slot) { return (!slot.islockedslot && slot.category == "None") }).length; var leftToFill = Math.min((maxAssignedSlots - assignedSlots),emptySlotsLeft); console.log("Epic", T3_Epic, "Rare", T3_Rare, "Uncommon", T3_Uncommon, "Slots to fill", leftToFill); if (T3_Epic + T3_Rare + T3_Uncommon > leftToFill) break; if (T3_Epic + T3_Rare + T3_Uncommon <= leftToFill) { quality = [".Bronze"]; }; } break; case 3: $select1 = $persons; $select2 = $persons; break; case 4: $select1 = $persons; $select2 = $persons; quality = quality.reverse(); break; case 5: $select1 = $assets; $select2 = $assets; break; case 6: $select1 = $assets; $select2 = $persons; quality = [".Special"]; break; case 7: $select1 = $assets; $select2 = $persons; quality = [".Gold"]; break; case 8: $select1 = $assets; $select2 = $persons; quality = [".Silver"]; break; case 9: $select1 = $assets; $select2 = $persons; quality = [".Bronze"]; break; } function clickLeadershipBronze() { var mercenarys = $('div.modal-item-list a.Bronze img[src*="Crafting_Follower_Leader_Generic_T1_01"]').parent().parent(); var guards = $('div.modal-item-list a.Bronze img[src*="Crafting_Follower_Leader_Guard_T2_01"]').parent().parent(); var footmen = $('div.modal-item-list a.Bronze img[src*="Crafting_Follower_Leader_Private_T2_01"]').parent().parent(); if (mercenarys.length) { mercenarys[0].click(); return true; } if (guards.length) { guards[0].click(); return true; } if (footmen.length) { footmen[0].click(); return true; } return false; } if (!clicked) { for (ic in quality) { $it = $select1.filter(quality[ic]); if ($it.length) { if (prof.taskName === "Leadership" && $select1 == $persons && quality[ic] == ".Bronze") { clicked = clickLeadershipBronze(); } else { $it[0].click(); clicked = true; } break; } } } // if no asset was selected, check for persons for best speed, in descending order if (!clicked) { for (ic in quality) { $it = $select2.filter(quality[ic]); if ($it.length) { if (prof.taskName === "Leadership" && $select2 == $persons && quality[ic] == ".Bronze") { clicked = clickLeadershipBronze(); } else { $it[0].click(); clicked = true; } break; } } } // if nothing was found at all, return immediately (skip other optional slots) if (!clicked) { $("button.close-button").trigger('click'); console.log("Nothing more to click.."); WaitForState("").done(function() { // Let main loop continue def.resolve(); }); } console.log("Clicked item"); WaitForState("").done(function() { // Get the new set of select buttons created since the other ones are removed when the asset loads var buttonList = $('.taskdetails-assets:eq(1)').find("button"); if (i < buttonList.length - 1) { SelectItemFor(buttonList, i + 1, def, prof, taskname, profname, profile, professionLevel, options); } else { // Let main loop continue def.resolve(); } }); }); } /** * Will buy a given purchasable resource * * @param {String} item The data-tt-item id of the Resource to purchase */ function buyResource(item) { var _resourceID = { Crafting_Resource_Charcoal: 0, Crafting_Resource_Rocksalt: 1, Crafting_Resource_Spool_Thread: 2, Crafting_Resource_Porridge: 3, Crafting_Resource_Solvent: 4, Crafting_Resource_Brimstone: 5, Crafting_Resource_Coal: 6, Crafting_Resource_Moonseasalt: 7, Crafting_Resource_Quicksilver: 8, Crafting_Resource_Spool_Threadsilk: 9, }; var _resourceCost = { Crafting_Resource_Charcoal: 30, Crafting_Resource_Rocksalt: 30, Crafting_Resource_Spool_Thread: 30, Crafting_Resource_Porridge: 30, Crafting_Resource_Solvent: 20, Crafting_Resource_Brimstone: 100, Crafting_Resource_Coal: 500, Crafting_Resource_Moonseasalt: 500, Crafting_Resource_Quicksilver: 500, Crafting_Resource_Spool_Threadsilk: 500, }; var _charGold = unsafeWindow.client.dataModel.model.ent.main.currencies.gold; var _charSilver = unsafeWindow.client.dataModel.model.ent.main.currencies.silver; var _charCopper = unsafeWindow.client.dataModel.model.ent.main.currencies.copper; var _charCopperTotal = _charCopper + (_charSilver * 100) + (_charGold * 10000); var _resourcePurchasable = Math.floor(_charCopperTotal / _resourceCost[item]); // Limit resource purchase to 50 quantity var _purchaseCount = (_resourcePurchasable >= 50) ? 50 : _resourcePurchasable; if (_purchaseCount < 1) { // Not enough gold for 1 resource console.log("Purchasing profession resources failed for: ", item, " Have: ",_charCopperTotal, " Cost Per Item: ", _resourceCost[item], " Can buy: ", _resourcePurchasable); if (pleaseBuy.push("Please buy " + item + " for " + unsafeWindow.client.getCurrentCharAtName()) > 5) { pleaseBuy.shift(); } return false; } else { // Make purchase console.log("Purchasing profession resources:", _purchaseCount + "x", item, ". Total copper available:", _charCopperTotal, ". Spending ", (_purchaseCount * _resourceCost[item]), "copper."); unsafeWindow.client.sendCommand("GatewayVendor_PurchaseVendorItem", { vendor: 'Nw_Gateway_Professions_Merchant', store: 'Store_Crafting_Resources', idx: _resourceID[item], count: _purchaseCount }); WaitForState("button.closeNotification").done(function() { $("button.closeNotification").trigger('click'); }); return null; } } /** DRAFT * Will buy a missing leadership assets * * @param {String} item reference from assetID */ function buyTaskAsset(_itemNo) { var _returnHast = unsafeWindow.location.hash; unsafeWindow.location.hash = unsafeWindow.location.hash.replace(/\)\/.+/, ')/professions/vendor'); WaitForState("").done(function() { if ($('span.alert-red button[data-url-silent="/professions/vendor/Store_Crafting_Assets/' + _itemNo + '"]').length) { return false; } else if ($('button[data-url-silent="/professions/vendor/Store_Crafting_Assets/' + _itemNo + '"]').length) { $('button[data-url-silent="/professions/vendor/Store_Crafting_Assets/' + _itemNo + '"]').trigger('click'); WaitForState(".modal-confirm button").done(function() { $('.modal-confirm button').eq(1).trigger('click'); unsafeWindow.location.hash = _returnHast; return null; }); } }); } // Function used to check exchange data model and post calculated AD/Zen for transfer if all requirements are met function postZaxOffer() { // Make sure the exchange data is loaded to model if (unsafeWindow.client.dataModel.model.exchangeaccountdata) { // Check that there is atleast 1 free ZAX order slot if (unsafeWindow.client.dataModel.model.exchangeaccountdata.openorders.length < 5) { // Place the order var exchangeDiamonds = parseInt(unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimescrow); if (exchangeDiamonds > 0) { console.log("AD in exchange: " + exchangeDiamonds); } // Domino effect: this new order will post all the gathered diamonds until now var charDiamonds = parseInt(unsafeWindow.client.dataModel.model.ent.main.currencies.diamonds); var ZenRate = parseInt(accountSettings.consolidationSettings.transferRate); if (!ZenRate) return; var ZenQty = Math.floor((charDiamonds + exchangeDiamonds - parseInt(getSetting('consolidationSettings','minCharBalance'))) / ZenRate); ZenQty = (ZenQty > 5000) ? 5000 : ZenQty; console.log("Posting ZAX buy listing for " + ZenQty + " ZEN at the rate of " + ZenRate + " AD/ZEN. AD remainder: " + charDiamonds + " - " + (ZenRate * ZenQty) + " = " + (charDiamonds - (ZenRate * ZenQty))); unsafeWindow.client.createBuyOrder(ZenQty, ZenRate); // set moved ad to the ad counter zax log var ADTotal = ZenRate * ZenQty - exchangeDiamonds; if (ADTotal > 0) { console.log("AD moved to ZAX from", charNamesList[lastCharNum] + ":", ADTotal); chardiamonds[lastCharNum] -= ADTotal; console.log(charNamesList[lastCharNum] + "'s", "Astral Diamonds:", chardiamonds[lastCharNum]); zaxdiamonds += ADTotal; console.log("Astral Diamonds on the ZAX:", zaxdiamonds); } } else { console.log("Zen Max Listings Reached (5). Skipping ZAX Posting.."); } } else { console.log("Zen Exchange data did not load in time for transfer. Skipping ZAX Posting.."); } } // Function used to check exchange data model and withdraw listed orders that use the settings zen transfer rate function cancelZaxOffer() { // Make sure the exchange data is loaded to model if(unsafeWindow.client.dataModel.model.exchangeaccountdata) { if(unsafeWindow.client.dataModel.model.exchangeaccountdata.openorders.length >= 1) { console.log("Canceling ZAX orders"); var charDiamonds = parseInt(unsafeWindow.client.dataModel.model.ent.main.currencies.diamonds); var ZenRate = parseInt(accountSettings.consolidationSettings.transferRate); // cycle through the zax listings unsafeWindow.client.dataModel.model.exchangeaccountdata.openorders.forEach(function(item) { // find any buy orders in the list with our set zen rate if (parseInt(item.price) == ZenRate && item.ordertype == "Buy") { // cancel/withdraw the order client.withdrawOrder(item.orderid); console.log("Cancelling ZAX offer for " + item.quantity + " ZEN at the rate of " + item.price + " . Total value in AD: " + item.totaltc); } }); } else { console.log("No listings found on ZAX. Skipping ZAX Withdraw.."); } } else { console.log("Zen Exchange data did not load in time for transfer. Skipping ZAX Withdraw.."); } } function claimZaxOffer() { if (unsafeWindow.client.dataModel.model.exchangeaccountdata) { if (parseInt(unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimescrow) > 0) { unsafeWindow.client.sendCommand("GatewayExchange_ClaimTC", unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimescrow); console.log("Attempting to withdraw exchange balances... ClaimTC: " + unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimescrow); // clear the ad counter zax log zaxdiamonds = 0; } if (parseInt(unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimmtc) > 0) { unsafeWindow.client.sendCommand("GatewayExchange_ClaimMTC", unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimmtc); console.log("Attempting to withdraw exchange balances... ClaimMT: " + unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimmtc); } } else { window.setTimeout(claimZaxOffer, delay.SHORT); } } // MAC-NW function vendorItemsLimited(_items) { var _pbags = client.dataModel.model.ent.main.inventory.playerbags; var _delay = 400; var _sellCount = 0; var _classType = unsafeWindow.client.dataModel.model.ent.main.classtype; var _bagCount = unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags.length; var _bagUsed = 0; var _bagUnused = 0; var _tmpBag = []; var _profitems = []; // Pattern for items to leave out of auto vendoring (safeguard) var _excludeItems = /(Gemfood|Gem_Upgrade_Resource_R[3-9]|Artifact(?!_Upgrade_Resource_R1_)|Hoard|Coffer|Fuse|Ward|Preservation|Armor_Enhancement|Weapon_Enhancement|T[6-9]_Enchantment|T[1-9][0-9]_Enchantment|T[6-9]_Runestone|T[1-9][0-9]_Runestone|4c_Personal|Item_Potion_Companion_Xp|Gateway_Rewardpack|Consumable_Id_Scroll|Dungeon_Delve_Key)/; // edited by RottenMind 17.01.2015 /** Profession leveling result item cleanup logic for T1-4 crafted results * Created by RM on 14.1.2015. * List contains crafted_items, based "Mustex/Bunta NW robot 1.05.0.1L crafting list, can be used making list for items what are "Auto_Vendored". * Items on list must be checked and tested. */ if (getSetting('vendorSettings', 'vendorProfResults')) { /*#2, Tier2 - tier3 mixed, upgrade, sell if inventory full, "TierX" is here "TX" */ _profitems[_profitems.length] = { pattern: /^Crafted_(Jewelcrafting_Neck_Misc_2|Jewelcrafting_Waist_Misc_2|Med_Armorsmithing_T3_Chain_Pants|Med_Armorsmithing_T3_Chain_Shirt|Hvy_Armorsmithing_T3_Plate_Pants|Hvy_Armorsmithing_T3_Plate_Shirt|Leatherworking_T3_Leather_Pants|Leatherworking_T3_Leather_Shirt|Tailoring_T3_Cloth_Shirt|Tailoring_T3_Cloth_Pants||Artificing_T3_Pactblade_Temptation_4|Artificing_T3_Icon_Virtuous_4|Weaponsmithing_T2_Dagger_3|Weaponsmithing_T2_Dagger_3)$/, limit: 0, count: 0 }; /*#3, Tier2, upgrade, sell if inventory full, "TierX" is here "TX" */ _profitems[_profitems.length] = { pattern: /^Crafted_(Jewelcrafting_Neck_Offense_2|Jewelcrafting_Waist_Offense_2|Med_Armorsmithing_T2_Chain_Armor_Set_1|Med_Armorsmithing_T2_Chain_Pants_2|Med_Armorsmithing_T2_Chain_Boots_Set_1|Med_Armorsmithing_T2_Chain_Shirt_2|Med_Armorsmithing_T2_Chain_Pants_1|Med_Armorsmithing_T2_Chain_Shirt|Hvy_Armorsmithing_T2_Plate_Armor_Set_1|Hvy_Armorsmithing_T2_Plate_Pants_2|Hvy_Armorsmithing_T2_Plate_Boots_Set_1|Hvy_Armorsmithing_T2_Plate_Shirt_2|Hvy_Armorsmithing_T2_Plate_Pants_1|Hvy_Armorsmithing_T2_Shield_Set_1|Hvy_Armorsmithing_T2_Plate_Shirt|Leatherworking_T2_Leather_Shirt|Leatherworking_T2_Leather_Boots_Set_1|Leatherworking_T2_Leather_Shirt_2|Leatherworking_T2_Leather_Pants_1|Leatherworking_T2_Leather_Armor_Set_1|Leatherworking_T2_Leather_Pants_2|Tailoring_T2_Cloth_Armor_Set_1|Tailoring_T2_Cloth_Pants_2|Tailoring_T2_Cloth_Boots_Set_1|Tailoring_T2_Cloth_Shirt_2|Tailoring_T2_Cloth_Pants_1|Artificing_T2_Pactblade_Temptation_3|Artificing_T1_Icon_Virtuous_2|Weaponsmithing_T2_Dagger_2)$/, limit: 0, count: 0 }; /*#4, Tier1, upgrade, sell if inventory full, "TierX" is here "TX" */ _profitems[_profitems.length] = { pattern: /^Crafted_(Jewelcrafting_Neck_Misc_1|Jewelcrafting_Waist_Misc_1|Med_Armorsmithing_T1_Chain_Armor_Set_1|Med_Armorsmithing_T1_Chain_Boots_Set_1|Hvy_Armorsmithing_Plate_Armor_1|Hvy_Armorsmithing_T1_Plate_Armor_Set_1|Hvy_Armorsmithing_T1_Plate_Boots_Set_1|Leatherworking_T1_Leather_Boots_Set_1|Leatherworking_T1_Leather_Boots_Set_1|Leatherworking_T1_Leather_Armor_Set_1|Tailoring_T1_Cloth_Armor_1|Tailoring_T1_Cloth_Pants_1|Tailoring_T1_Cloth_Boots_Set_1|Artificing_T1_Pactblade_Convergence_2|Artificing_T1_Icon_Virtuous_2|Weaponsmithing_T1_Dagger_1)$/, limit: 0, count: 0 }; /*#5, Tier0, upgrade, sell if inventory full, taskilist "Tier1" is here "empty" or "_" must replace (_T1_|_)*/ _profitems[_profitems.length] = { pattern: /^Crafted_(Jewelcrafting_Waist_Offense_1|Jewelcrafting_Neck_Offense_1|Med_Armorsmithing_Chain_Boots_1|Med_Armorsmithing_Chain_Shirt_1|Med_Armorsmithing_Chain_Armor_1|Med_Armorsmithing_Chain_Pants_1|Hvy_Armorsmithing_Plate_Boots_1|Hvy_Armorsmithing_Plate_Shirt_1|Hvy_Armorsmithing_Shield_1|Leatherworking_Tier0_Intro_1|Leatherworking_Leather_Boots_1|Leatherworking_Leather_Shirt_1|Leatherworking_Leather_Armor_1|Leatherworking_Leather_Pants_1|Tailoring_Cloth_Boots_1|Tailoring_Cloth_Shirt_1|Artificing_T1_Pactblade_Convergence_1|Artificing_Icon_Virtuous_1|Artificing_Symbol_Virtuous_1|Weaponsmithing_Dagger_1)$/, limit: 0, count: 0 }; } $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { // Match unused slots if (slot === null || !slot || slot === undefined) { _bagUnused++; } // Match items to exclude from auto vendoring, don't add to _tmpBag: Exclude pattern list - bound - Epic Quality - Legendary Quality - Mythic Quality else if (_excludeItems.test(slot.name) || slot.rarity == "Special" || slot.rarity == "Legendary" || slot.rarity == "Mythic") { _bagUsed++; } // Match everything else else { if (getSetting('vendorSettings', 'vendorProfResults')) { for (i = 0; i < _profitems.length; i++) { if (_profitems[i].pattern.test(slot.name)) _profitems[i].count++; } } _tmpBag[_tmpBag.length] = slot; _bagUsed++; } }); }); if (getSetting('vendorSettings', 'vendorProfResults')) { _tmpBag.forEach(function(slot) { for (i = 0; i < _profitems.length; i++) { // edited by RottenMind if (slot && _profitems[i].pattern.test(slot.name) && Inventory_bagspace() <= 7) { // !slot.bound && _profitems[i].count > 3 &&, edited by RottenMind var vendor = { vendor: "Nw_Gateway_Professions_Merchant" }; vendor.id = slot.uid; vendor.count = 1; console.log('Selling', vendor.count, slot.name, 'to vendor.'); window.setTimeout(function() { client.sendCommand('GatewayVendor_SellItemToVendor', vendor); }, _delay); _profitems[i].count--; break; } } }); } _tmpBag.forEach(function(slot) { for (i = 0; i < _items.length; i++) { var _Limit = (parseInt(_items[i].limit) > 99) ? 99 : _items[i].limit; if (slot && _items[i].pattern.test(slot.name)) { // Node Kits vendor logic for restricted bag space if (getSetting('vendorSettings', 'vendorKitsLimit') && /^Item_Consumable_Skill/.test(slot.name)) { if (_bagCount < 2 || _bagUnused < 6 || (slot.name == "Item_Consumable_Skill_Dungeoneering" && (_classType == "Player_Guardian" || _classType == "Player_Greatweapon")) || (slot.name == "Item_Consumable_Skill_Arcana" && (_classType == "Player_Controller" || _classType == "Player_Scourge")) || (slot.name == "Item_Consumable_Skill_Religion" && _classType == "Player_Devoted") || (slot.name == "Item_Consumable_Skill_Thievery" && _classType == "Player_Trickster") || (slot.name == "Item_Consumable_Skill_Nature" && _classType == "Player_Archer")) { _Limit = 0; } } // Sell Items if (slot.count > _Limit) { _sellCount++; var vendor = { vendor: "Nw_Gateway_Professions_Merchant" }; vendor.id = slot.uid; vendor.count = slot.count - _Limit; console.log('Selling', vendor.count, slot.name, 'to vendor.'); window.setTimeout(function() { client.sendCommand('GatewayVendor_SellItemToVendor', vendor); }, _delay); _delay = _delay + 400; break; } } } }); return _sellCount; } function switchChar() { // detect if daily reset occurs (no more frequently than every 16 hours) var oldRefineToday = charStatisticsList[curCharName].general.refined[0] | 0; var newRefineToday = unsafeWindow.client.dataModel.model.ent.main.currencies.diamondsconverted | 0; if (newRefineToday < oldRefineToday) { if (accountSettings.generalSettings.SCADailyReset < Date.now() - 16*60*60*1000) { accountSettings.generalSettings.SCADailyReset = Date.now(); GM_setValue("settings__account__" + loggedAccount, JSON.stringify(accountSettings)); } } if (newRefineToday < oldRefineToday || charStatisticsList[curCharName].general.lastVisit < lastDailyResetTime) { if (!Array.isArray(charStatisticsList[curCharName].general.refined)) { var temp = [0,0,0,0,0,0,0,0]; temp[0] = charStatisticsList[curCharName].general.refined; charStatisticsList[curCharName].general.refined = temp; } charStatisticsList[curCharName].general.refined.unshift(0); charStatisticsList[curCharName].general.refined.length = 8; } var refined_diamonds = 0; if (getSetting('generalSettings', 'refineAD')) { var _currencies = unsafeWindow.client.dataModel.model.ent.main.currencies; if (_currencies.diamondsconvertleft && _currencies.roughdiamonds) { if (_currencies.diamondsconvertleft < _currencies.roughdiamonds) { refined_diamonds = _currencies.diamondsconvertleft } else { refined_diamonds = _currencies.roughdiamonds } chardiamonds[curCharNum] += refined_diamonds console.log("Refining AD for", curCharName + ":", refined_diamonds); console.log(curCharName + "'s", "Astral Diamonds:", chardiamonds[curCharNum]); unsafeWindow.client.sendCommand('Gateway_ConvertNumeric', 'Astral_Diamonds'); WaitForState("button.closeNotification").done(function() { $("button.closeNotification").click(); }); charStatisticsList[curCharName].general.refineCounter += refined_diamonds; } } // MAC-NW -- AD Consolidation //if (accountSettings.consolidationSettings.consolidate) { if (getSetting('consolidationSettings','consolidate')) { // Check that we dont take money from the character assigned as the banker // Zen Transfer / Listing if ((accountSettings.consolidationSettings.bankCharName) && (accountSettings.consolidationSettings.bankCharName !== unsafeWindow.client.dataModel.model.ent.main.name)) { // Check the required min AD amount on character if (getSetting('consolidationSettings','minToTransfer') && parseInt(unsafeWindow.client.dataModel.model.ent.main.currencies.diamonds) >= (parseInt(getSetting('consolidationSettings','minToTransfer')) + parseInt(getSetting('consolidationSettings','minCharBalance')))) { // Check that the rate is not less than the min & max if (accountSettings.consolidationSettings.transferRate && parseInt(accountSettings.consolidationSettings.transferRate) >= 50 && parseInt(accountSettings.consolidationSettings.transferRate) <= 500) { window.setTimeout(postZaxOffer, delay.SHORT); } else { console.log("Zen transfer rate does not meet the minimum (50) or maximum (500). Skipping ZAX Posting.."); } } else { console.log("Character does not have minimum AD balance to do funds transfer. Skipping ZAX Posting.."); } } else { console.log("Bank char not set or bank char, skipping posting."); } } else { console.log("Zen Exchange AD transfer not enabled. Skipping ZAX Posting.."); } if (getSetting('generalSettings','openRewards')) { var _pbags = unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags; var _cRewardPat = /Reward_Item_Chest|Gateway_Rewardpack|Rewardpack_Invocation_Mechanical/; console.log("Opening Rewards"); $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot && _cRewardPat.test(slot.name)) { if (slot.count >= 99) slot.count = 99; var reserve = getSetting('generalSettings', 'keepOneUnopened') ? 1 : 0; for (i = 1; i <= (slot.count - reserve); i++) { window.setTimeout(function() { client.sendCommand('GatewayInventory_OpenRewardPack', slot.uid); }, 500); } } }); }); } if (getSetting('generalSettings','openCelestialBox')) { var _pbags = unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags; var _cRewardPat = /Invocation_Reward_Celestial_Artifact_Equipment_Box|Invocation_Reward_Celestial_Artifacts_Box|Invocation_Reward_Celestial_Enchantments_Box/; console.log("Opening Celestial Boxes"); $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot && _cRewardPat.test(slot.name)) { if (slot.count >= 99) slot.count = 99; var reserve = getSetting('generalSettings', 'keepOneUnopened') ? 1 : 0; for (i = 1; i <= (slot.count - reserve); i++) { window.setTimeout(function() { client.sendCommand('GatewayInventory_OpenRewardPack', slot.uid); }, 500); } } }); }); } if (getSetting('generalSettings','openInvocation')) { var _pbags = unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags; var _cRewardPat = /Invocation_Rp_Bag/; console.log("Opening Invocation Rewards"); $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot && _cRewardPat.test(slot.name)) { window.setTimeout(function() { client.sendCommand('GatewayInventory_OpenRewardPack', slot.uid); }, 500); } }); }); } if (getSetting('generalSettings','openVIP')) { var _pbags = unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags; var _cRewardPat = /Vip_Account_Perdiem/; console.log("Opening Account Bound VIP Rewards"); $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot && _cRewardPat.test(slot.name)) { window.setTimeout(function() { client.sendCommand('GatewayInventory_OpenRewardPack', slot.uid); }, 500); } }); }); } // Check Vendor Options & Vendor matched items vendorJunk(); // MAC-NW (endchanges) // Updating statistics console.log('Updating statistics'); var _stat = charStatisticsList[curCharName].general; var _chardata = unsafeWindow.client.dataModel.model.ent.main.currencies; _stat.lastVisit = Date.now(); _stat.gold = parseInt(_chardata.gold); _stat.rad = parseInt(_chardata.roughdiamonds - refined_diamonds); // refined_diamonds: removing and adding manually to compensate for slow model update _stat.diamonds = parseInt(_chardata.diamonds + refined_diamonds); _stat.rBI = parseInt(_chardata.rawblackice); _stat.BI = parseInt(_chardata.blackice); _stat.refined[0] = parseInt(_chardata.diamondsconverted + refined_diamonds); _stat.diamondsconvertleft = parseInt(_chardata.refineLimitLeft); _stat.activeSlots = unsafeWindow.client.dataModel.model.ent.main.itemassignments.active; _stat.celestial = parseInt(_chardata.celestial); _stat.ardent = parseInt(_chardata.ardent); //clearing charStatisticsList[curCharName].trackedResources = []; $.each(charStatisticsList[curCharName].tools, function(name, obj) { obj.used = []; obj.unused = []; }); $.each(charStatisticsList[curCharName].professions, function(name, obj) { obj.workersUsed = []; obj.workersUnused = []; obj.level = 0; }); trackResources.forEach(function(resource, ri) { charStatisticsList[curCharName].trackedResources[ri] = 0; }); // Counting main inventory bags charStatisticsList[curCharName].general.emptyBagSlots = 0; charStatisticsList[curCharName].general.bagSlots = 0; unsafeWindow.client.dataModel.model.ent.main.inventory.playerbags .forEach(function (bag) { bag.slots.forEach( function (slot, slotNum) { charStatisticsList[curCharName].general.bagSlots += 1; if (!slot) { charStatisticsList[curCharName].general.emptyBagSlots += 1; return; } trackResources.forEach(function(resource, ri) { if (slot.name === resource.name) { if ((resource.unbound && !slot.bound && !slot.boundtoaccount) || (resource.btc && slot.bound && !slot.boundtoaccount) || (resource.bta && slot.boundtoaccount)) { charStatisticsList[curCharName].trackedResources[ri] += slot.count; } } }); }); }); // Counting the rest of the bags trackResources.forEach(function(resource, ri) { unsafeWindow.client.dataModel.model.ent.main.inventory.bags .filter(function(bag) { return ((["CraftingResources", "Overflow", "CraftingInventory"].indexOf(bag.bagid) > -1) || (resource.bank && bag.bagid == "Bank")); }) .forEach(function(bag) { bag.slots.forEach( function (slot, slotNum) { if (slot && slot.name === resource.name) { if ((resource.unbound && !slot.bound && !slot.boundtoaccount) || (resource.btc && slot.bound && !slot.boundtoaccount) || (resource.bta && slot.boundtoaccount)) { charStatisticsList[curCharName].trackedResources[ri] += slot.count; } } }); }); }); // Counting Resource slots charStatisticsList[curCharName].general.emptyResourceSlots = 0; charStatisticsList[curCharName].general.resourceSlots = 0; unsafeWindow.client.dataModel.model.ent.main.inventory.bags .filter(function(bag) { return (["CraftingResources"].indexOf(bag.bagid) > -1); }) .forEach(function(bag) { bag.slots.forEach( function (slot, slotNum) { charStatisticsList[curCharName].general.resourceSlots += 1; if (!slot) { charStatisticsList[curCharName].general.emptyResourceSlots += 1; } }); }); // Counting overflow charStatisticsList[curCharName].general.overflow = 0; unsafeWindow.client.dataModel.model.ent.main.inventory.bags .filter(function(bag) { return (["Overflow"].indexOf(bag.bagid) > -1); }) .forEach(function(bag) { charStatisticsList[curCharName].general.overflow += bag.slots.length; }); // Slot assignment unsafeWindow.client.dataModel.model.ent.main.itemassignments.assignments.forEach(function(slot, ix) { if (!slot.islockedslot && slot.category !== "None") { charStatisticsList[curCharName].slotUse[ix] = slot.category; } else if (slot.islockedslot) { charStatisticsList[curCharName].slotUse[ix] = "----"; // Locked Slot } else { charStatisticsList[curCharName].slotUse[ix] = "OPEN"; // Un-Assigned Slot!!! } }); // Workers and tools assignment and qty unsafeWindow.client.dataModel.model.ent.main.inventory.assignedslots .forEach(function(item) { $.each(workerList, function(pName, pList) { var index = pList.indexOf(item.name); if (index > -1) { charStatisticsList[curCharName].professions[pName].workersUsed[index] = item.count; } }); $.each(toolList, function(tName, tList) { var index = tList.indexOf(item.name); if (index > -1) { charStatisticsList[curCharName].tools[tName].used[index] = item.count; } }); }); unsafeWindow.client.dataModel.model.ent.main.inventory.notassignedslots .forEach(function(item) { $.each(workerList, function(pName, pList) { var index = pList.indexOf(item.name); if (index > -1) { charStatisticsList[curCharName].professions[pName].workersUnused[index] = item.count; } }) $.each(toolList, function(tName, tList) { var index = tList.indexOf(item.name); if (index > -1) { charStatisticsList[curCharName].tools[tName].unused[index] = item.count; } }) }); // getting profession levels from currentrank, model has displayname, name, and category, using displayname (platesmithing) // Must match the names in charStatisticsList[curCharName].professions unsafeWindow.client.dataModel.model.ent.main.itemassignmentcategories.categories .forEach(function(prof) { if (charStatisticsList[curCharName].professions[prof.displayname]) { charStatisticsList[curCharName].professions[prof.displayname].level = prof.currentrank; } }); charStatisticsList[curCharName].general.nextTask = chartimers[curCharNum]; GM_setValue("statistics__char__" + curCharFullName , JSON.stringify(charStatisticsList[curCharName])); updateCounters(); // TODO: refactor this block into function and merge with the similar in charSCA() console.log("Switching Characters"); lastCharNum = curCharNum; var chardelay, chardate = null, nowdate = new Date(); nowdate = nowdate.getTime(); var not_active = 0; charNamesList.every( function (charName, idx) { if (!charSettingsList[charName].general.active) { not_active++; return true; } if (chartimers[idx] != null) { console.log("Date found for " + charName); if (!chardate || chartimers[idx] < chardate) { chardate = chartimers[idx]; curCharNum = idx; chardelay = chardate.getTime() - nowdate - unsafeWindow.client.getServerOffsetSeconds() * 1000; if (chardelay < delay.SHORT) { chardelay = delay.SHORT; } } return true; } curCharNum = idx; chardelay = delay.SHORT; chardate = null; console.log("No date found for " + charName + ", switching now."); return false; // = break; }); // Change to optional ? if (chardelay > delay.SHORT) chardelay = chardelay + (Math.random() + 0.3) * delay.DEFAULT; curCharName = charNamesList[curCharNum]; curCharFullName = curCharName + "@" + loggedAccount; failedTasksList = []; failedProfiles = {}; var k = 9; while (k) {collectTaskAttempts[--k] = 0}; //collectTaskAttempts.fill(0); if (getSetting('consolidationSettings','consolidate')) { // Withdraw AD from the ZAX into the banker character if (accountSettings.consolidationSettings.bankCharName == curCharName) { window.setTimeout(cancelZaxOffer, delay.SHORT); } } // Count AD & Gold var curdiamonds = zaxdiamonds; var curgold = 0; charNamesList.forEach( function (charName, idx) { if (chardiamonds[idx] != null) { curdiamonds += Math.floor(chardiamonds[idx] / 50) * 50; } if (chargold[idx] != null) { curgold += chargold[idx]; } }); console.log("Next run for " + curCharName + " in " + parseInt(chardelay / 1000) + " seconds."); $("#prinfopane").empty(); var ptext = $("<h3 class='promo-image copy-top prh3'>Professions Robot<br />Next task for " + curCharName + "<br /><span data-timer='" + chardate + "' data-timer-length='2'></span><br />Diamonds: " + curdiamonds.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",") + "<br />Gold: " + curgold + (pleaseBuy.length > 0 ? "<br />" : "") + pleaseBuy.join("<br />") + "</h3>") .appendTo("#prinfopane"); charNamesList.forEach( function (charName, idx) { if (leadershipSlots[charName] > new Date()) { ptext.append("<div>Open Leadership slot for " + charName + "! (<span data-timer='" + leadershipSlots[charName] + "' data-timer-length='2'></span>) <span id='lsignore" + idx + "' " + "style='cursor: pointer'>Ignore</span> / <span id='lsdone" + idx + "' " + "style='cursor: pointer'>Done</span></div>"); $("#lsignore" + idx).click( function () { IgnoreButton(idx, false); $(this).parent().empty(); }); $("#lsdone" + idx).click( function () { IgnoreButton(idx, true); $(this).parent().empty(); }); } }); if (not_active == charNamesList.length) { ptext.append("<div class='h_warning'>No Active chars found!</div>"); console.warn("No Active chars found!"); } GM_setValue("curCharNum_" + loggedAccount, curCharNum); var runSCAtime = !charStatisticsList[charNamesList[lastCharNum]].general.lastSCAVisit || ((charStatisticsList[charNamesList[lastCharNum]].general.lastSCAVisit + (1000*60*60*24)) < Date.now()) || (charStatisticsList[charNamesList[lastCharNum]].general.lastSCAVisit < accountSettings.generalSettings.SCADailyReset) || (charStatisticsList[charNamesList[lastCharNum]].general.lastSCAVisit < lastDailyResetTime.getTime()); var sca_setting = getSetting('generalSettings','runSCA'); var runSCA = (runSCAtime && (sca_setting !== 'never')); runSCA = runSCA && (sca_setting === 'always' || (sca_setting === 'free' && chardelay > 7000)); // More than 7 seconds for the next char swap console.log("Check if need to run SCA for " + charNamesList[lastCharNum] + ": " + sca_setting + " " + runSCAtime); if (runSCA) { unsafeWindow.location.hash = unsafeWindow.location.hash.replace(/\)\/.+/, ')' + "/adventures"); processCharSCA(lastCharNum); return; } dfdNextRun.resolve(chardelay); } /** * Waits for the loading symbol to be hidden. * * @return {Deferred} A jQuery defferred object that will be resolved when loading is complete */ function WaitForLoad() { return WaitForState(""); } /** * Creates a deferred object that will be resolved when the state is reached * * @param {string} query The query for the state to wait for * @return {Deferred} A jQuery defferred object that will be resolved when the state is reached */ function WaitForState(query) { var dfd = $.Deferred(); window.setTimeout(function() { AttemptResolve(query, dfd); }, delay.SHORT); // Doesn't work without a short delay return dfd; } function WaitForNotState(query) { var dfd = $.Deferred(); window.setTimeout(function() { AttemptNotResolve(query, dfd); }, delay.SHORT); // Doesn't work without a short delay return dfd; } /** * Will continually test for the given query state and resolve the given deferred object when the state is reached * and the loading symbol is not visible * * @param {string} query The query for the state to wait for * @param {Deferred} dfd The jQuery defferred object that will be resolved when the state is reached */ function AttemptResolve(query, dfd) { if ((query === "" || $(query).length) && $("div.loading-image:visible").length === 0) { dfd.resolve(); } else { window.setTimeout(function() { AttemptResolve(query, dfd); }, delay.SHORT); // Try again in a little bit } } /* Opposite of AttemptResolve, will try to resolve query until it doesn't resolve. */ function AttemptNotResolve(query, dfd) { if (!$(query).length && $("div.loading-image:visible").length === 0) { dfd.resolve(); } else { window.setTimeout(function() { AttemptNotResolve(query, dfd); }, delay.SHORT); // Try again in a little bit } } /** * The main process loop: * - Determine which page we are on and call the page specific logic * - When processing is complete, process again later * - Use a short timer when something changed last time through * - Use a longer timer when waiting for tasks to complete */ function process() { waitingNextChar = false; // Calculating last daily reset time var today = new Date(); var todayRest = new Date(Date.UTC(today.getUTCFullYear(), today.getUTCMonth(), today.getUTCDate(), 10,0,0)); if (today > todayRest) lastDailyResetTime = todayRest; else lastDailyResetTime = new Date(Date.UTC(today.getUTCFullYear(), today.getUTCMonth(), today.getUTCDate()-1, 10,0,0)); // Make sure the settings button exists addSettings(); // Enable/Disable the unconditional page reload depending on settings loading_reset = scriptSettings.general.scriptAutoReload; // Check if timer is paused s_paused = scriptSettings.general.scriptPaused; // let the Page Reloading function know the pause state if (s_paused) { // Just continue later - the deferred object is still set and nothing will resolve it until we get past this point timerHandle = window.setTimeout(function() { process(); }, delay.DEFAULT); return; } // Check for Gateway down if (window.location.href.indexOf("gatewaysitedown") > -1) { // Do a long delay and then retry the site console.log("Gateway down detected - relogging in " + (delay.MINS / 1000) + " seconds"); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, delay.MINS); return; } // Check for login or account guard and process accordingly var currentPage = GetCurrentPage(); if (currentPage === "Login") { page_LOGIN(); return; } else if (currentPage === "Guard") { page_GUARD(); return; } if (pleaseBuy.length == 0) { pleaseBuy['ts'] = Date.now() + 15*60*1000; } else if ((pleaseBuy['ts']||0) < Date.now()) { pleaseBuy.shift(); pleaseBuy['ts'] = Date.now() + 15*60*1000; } window.setTimeout(function() { loginProcess(); }, delay.SHORT); // Continue again later dfdNextRun.done(function(delayTimer) { waitingNextChar = true; dfdNextRun = $.Deferred(); timerHandle = window.setTimeout(function() { process(); }, typeof delayTimer !== 'undefined' ? delayTimer : delay.DEFAULT); }); //console.log("Process Timer Handle: " + timerHandle); } function loginProcess() { // Get logged on account details var accountName; try { accountName = unsafeWindow.client.dataModel.model.loginInfo.publicaccountname; } catch(e) { // TODO: Use callback function window.setTimeout(function() { loginProcess(); }, delay.SHORT); return; } // Check if timer is paused again to avoid starting new task between timers s_paused = scriptSettings.general.scriptPaused; // let the Page Reloading function know the pause state if (s_paused) { // Just continue later - the deferred object is still set and nothing will resolve it until we get past this point timerHandle = window.setTimeout(function() { process(); }, delay.DEFAULT); return; } if (accountName) { if (!loggedAccount || (loggedAccount != accountName)) { loggedAccount = accountName; console.log("Loading settings for " + accountName); var tempAccountSetting; try { tempAccountSetting = JSON.parse(GM_getValue("settings__account__" + accountName, "{}")); } catch (e) { tempAccountSetting = null; } if (!tempAccountSetting) { console.log('Account settings couldn\'t be retrieved, loading defaults.'); tempAccountSetting = {}; }; accountSettings = $.extend(true, {}, defaultAccountSettings, tempAccountSetting); console.log("Loading character list"); charNamesList = []; client.dataModel.model.loginInfo.choices.forEach(function(char) { if (char.shardname == "Dungeon") return; charNamesList.push(char.name); }); console.log("Found names: " + charNamesList); charNamesList.forEach(function(charName) { console.log("Loading settings for " + charName); var tempCharsSetting; try { tempCharsSetting = JSON.parse(GM_getValue("settings__char__" + charName + "@" + accountName, "{}")); } catch (e) { tempCharsSetting = null; } if (!tempCharsSetting) { tempCharsSetting = {}; console.log('Character settings couldn\'t be retrieved, loading defaults.'); }; charSettingsList[charName] = $.extend(true, {}, defaultCharSettings, tempCharsSetting); charSettingsList[charName].charName = charName; // for compatibility console.log("Loading saved statistics for " + charName); var tempCharsStatistics; try { tempCharsStatistics = JSON.parse(GM_getValue("statistics__char__" + charName + "@" + accountName, "{}")); } catch (e) { tempCharsStatistics = null; } if (!tempCharsStatistics) { console.log('Character statistics couldn\'t be retrieved, loading defaults.'); tempCharsStatistics = {}; }; charStatisticsList[charName] = $.extend(true, {}, defaultCharStatistics, tempCharsStatistics); }) if (scriptSettings.general.saveCharNextTime) charNamesList.forEach( function(name, idx) { chartimers[idx] = (new Date(charStatisticsList[name].general.nextTask)); chargold[idx] = charStatisticsList[name].general.gold; chardiamonds[idx] = charStatisticsList[name].general.diamonds; }); // Adding the Account and character settings / info to the UI addSettings(); } // load current character position and values curCharNum = GM_getValue("curCharNum_" + accountName, 0); curCharName = charNamesList[curCharNum]; curCharFullName = curCharName + '@' + accountName; if (unsafeWindow.client.getCurrentCharAtName() != curCharFullName) { loadCharacter(curCharFullName); return; } // Try to start tasks if (processCharacter()) { return; } // Switch characters as necessary switchChar(); } } function loadCharacter(charname) { // Load character and restart next load loop console.log("Loading gateway script for", charname); if (unsafeWindow.location.hash != "#char(" + encodeURI(charname) + ")/professions") { unsafeWindow.location.hash = "#char(" + encodeURI(charname) + ")/professions"; } unsafeWindow.client.dataModel.loadEntityByName(charname); try { var testChar = unsafeWindow.client.dataModel.model.ent.main.name; unsafeWindow.client.dataModel.fetchVendor('Nw_Gateway_Professions_Merchant'); console.log("Loaded datamodel for", charname); } catch (e) { // TODO: Use callback function window.setTimeout(function() { loadCharacter(charname); }, delay.SHORT); return; } // MAC-NW -- AD Consolidation -- Banker Withdraw Section if (getSetting('consolidationSettings','consolidate')) { unsafeWindow.client.dataModel.fetchExchangeAccountData(); try { var testExData = unsafeWindow.client.dataModel.model.exchangeaccountdata.openorders; console.log("Loaded zen exchange data for", charname); } catch (e) { // TODO: Use callback function window.setTimeout(function() { loadCharacter(charname); }, delay.SHORT); return; } // First check if there's anything we have to withdraw and claim it // Sometimes the system will literally overwrite cancelled and unclaimed orders and return AD to that character // Example: if you cancel 5 orders, don't claim them, then create another order and cancel it, that last order // will overwrite one of your previous orders and return the AD to that other character var exchangeDiamonds = parseInt(unsafeWindow.client.dataModel.model.exchangeaccountdata.readytoclaimescrow); if (exchangeDiamonds > 0) { claimZaxOffer(); } // Domino effect: first check if we're out of space for new offers if (unsafeWindow.client.dataModel.model.exchangeaccountdata.openorders.length == 5) { // Domino effect: then withdraw as much offers as we can and claim the diamonds window.setTimeout(cancelZaxOffer, delay.SHORT); } WaitForState("button.closeNotification").done(function() { $("button.closeNotification").click(); }); unsafeWindow.client.dataModel.loadEntityByName(charname); } else { console.log("Zen Exchange AD transfer not enabled. Skipping ZAX Posting.."); } // MAC-NW // MAC-NW -- Moved Professoin Merchant loading here with testing/waiting to make sure it loads try { var testProfMerchant = client.dataModel.model.vendor.items; console.log("Loaded profession merchant for", charname); } catch (e) { // TODO: Use callback function window.setTimeout(function() { loadCharacter(charname); }, delay.SHORT); return; } // Check Vendor Options & Vendor matched items vendorJunk(); dfdNextRun.resolve(); } function addSettings() { var setEventHandlers = false; if (!($("#settingsButton").length)) { // Add the required CSS AddCss("\ #content_box.section{margin-left: 120px !important;}\ #settingsButton{border-bottom: 1px solid rgb(102, 102, 102); border-right: 1px solid rgb(102, 102, 102); background: none repeat scroll 0% 0% rgb(238, 238, 238); display: block; position: fixed; overflow: auto; right: 0px; top: 0px; padding: 3px; z-index: 1000;}\ #pauseButton{border-bottom: 1px solid rgb(102, 102, 102); border-right: 1px solid rgb(102, 102, 102); background: none repeat scroll 0% 0% rgb(238, 238, 238); display: block; position: fixed; overflow: auto; right: 23px; top: 0px; padding: 3px; z-index: 1000;}\ #manualButton{border-bottom: 1px solid rgb(102, 102, 102); border-right: 1px solid rgb(102, 102, 102); background: none repeat scroll 0% 0% rgb(238, 238, 238); display: block; position: fixed; overflow: auto; right: 46px; top: 0px; padding: 3px; z-index: 1000;}\ #revisitButton{border-bottom: 1px solid rgb(102, 102, 102); border-right: 1px solid rgb(102, 102, 102); background: none repeat scroll 0% 0% rgb(238, 238, 238); display: block; position: fixed; overflow: auto; right: 69px; top: 0px; padding: 3px; z-index: 1000;}\ #settingsPanel{position: fixed; overflow: auto; right: 0px; top: 0px; min-width: 700px;max-width: 60%;max-height:100%;font: 12px sans-serif; text-align: left; display: block; z-index: 1001;}\ #settings_title{font-weight: bolder; background: none repeat scroll 0% 0% rgb(204, 204, 204); border-bottom: 1px solid rgb(102, 102, 102); padding: 3px;}\ #settingsPanelButtonContainer {background: none repeat scroll 0% 0% rgb(204, 204, 204); border-top: 1px solid rgb(102, 102, 102);padding: 3px;text-align:center} \ #charSettingsAccordion h3.inactive {color: LightGray ;}\ #charPanel {width:98%;max-height:550px;overflow:auto;display:block;padding:3px;}\ .inventory-container {float: left; clear: none; width: 270px; margin-right: 20px;}\ #prinfopane {position: fixed; top: 5px; left: 200px; display: block; z-index: 1000;}\ .prh3 {padding: 5px; height: auto!important; width: auto!important; background-color: rgba(0, 0, 0, 0.7);}\ .custom-radio{width:16px;height:16px;display:inline-block;position:relative;z-index:1;top:3px;background-color:#fff;margin:0 4px 0 2px;}\ .custom-radio:hover{background-color:black;} .custom-radio.selected{background-color:red;} .custom-radio-selected-text{color:darkred;font-weight:500;}\ .custom-radio input[type='radio']{margin:1px;position:absolute;z-index:2;cursor:pointer;outline:none;opacity:0;_nofocusline:expression(this.hideFocus=true);-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=0);filter:alpha(opacity=0);-khtml-opacity:0;-moz-opacity:0}\ .charSettingsTab { overflow: auto; }\ .charSettingsTab div { overflow: auto; }\ #rcounters ul li span { display: inline-block; min-width: 125px; }\ #settingsPanel table { width: 100%; }\ #settingsPanel table tbody tr:hover td { background-color: #aed0ea; }\ .ranked:nth-child(6n+2) { color: purple; } .ranked:nth-child(6n+3) { color: blue; } .ranked:nth-child(6n+4) { color: green } \ .ranked2:nth-child(6n+1) { color: purple; } .ranked2:nth-child(6n+2) { color: blue; } .ranked2:nth-child(6n+3) { color: green } \ .tranked:nth-child(4n+2) { color: purple; } .tranked:nth-child(4n+3) { color: blue; } .tranked:nth-child(4n) { color: green } \ .tranked2:nth-child(4n+1) { color: purple; } .tranked2:nth-child(4n+2) { color: blue; } .tranked2:nth-child(4n+3) { color: green } \ table.professionRanks { border-collapse: collapse; } \ table.professionRanks td { height: 14px; } \ td.ranked2, td.tranked2 { border-bottom: solid 1px #555; border-top: dashed 1px #888 }\ #resource_tracker {overflow-x:auto;}\ table.withRotation td.rotate, table.withRotation th.rotate { height: 125px; } \ table.withRotation td.rotate, table.withRotation th.rotate > div { transform: translate(0, 38px) rotate(290deg); width: 30px; } \ table.withRotation td.rotate, table.withRotation th.rotate > div > span { border-bottom: 1px solid #bbb; padding: 0px 0px; white-space: nowrap; } \ table.withRotation td { border-right: 1px solid #bbb; white-space: nowrap; } \ input[type='checkbox'].settingsInput { margin: 5px 10px 5px 5px; }\ input.settingsInput { margin: 5px 5px; }\ label.settingsLabel { margin: 5px 5px; min-width: 150px; display: inline-block; }\ .inputSaved { color: #66FF66; }\ .inputSaved:after { content: \"\"; width: 8px; height: 8px; display: inline-block; background-color: #66FF66; position:relative; right: 10px; }\ .h_warning { color: red !important; }\ label.customProfiles {min-width: 150px; }\ select.customProfiles { margin: 10px }\ textarea.customProfiles { width: 500px; height: 350px; margin: 10px 0; }\ .custom_profiles_delete { height: 16px; } #custom__profiles__viewbase_btn { height: 16px; } .custom_profiles_view {height: 16px; margin: 0 4px; }\ .custom_resources_delete { height: 16px; } .customResources input:not([type='checkbox']) { margin: 3px 10px } .customResources label { margin-right: 10px; }\ .customResources input[type='checkbox'] { margin-right: 10px } .customResources button { margin: 0 10px } div.customResources { margin: 10px 0;} \ #settingsPanel table {border-collapse: collapse; }\ tr.totals > td { border-bottom: 1px solid grey; padding-top: 3px; color: #000080 } \ .rarity_Gold {color: blue; } .rarity_Silver {color: green; } .rarity_Special {color: purple; } .rarity_Legendary {color: orange; } .rarity_Mythic {color: teal; } \ #dialog-inventory { overflow-y: scroll; font: 10px Arial; } #dialog-inventory table { width: 100% } #dialog-inventory table th { text-align: left; font-weight: bold; }\ .slt_None {color: red;} .slt_Lead {color: blue;} .slt_Alch {color: green;} .slt_Jewe {color: gold;} .slt_Leat {color: brown;}\ #copy_settings_to { width: 200px; height: 350px; margin: 5px 0;} #copy_settings_from { margin: 5px 0;}\ .warning1 { color: red; } .warning2 { color: orange; } .warning3 { color: green; }\ .profileInput { width: 150px; } label.settingsTaskName { min-width: 100px; }\ "); // Add settings panel to page body $("body").append( '<div id="settingsPanel" class="ui-widget-content">\ <div id="settings_title">\ <span class="ui-icon ui-icon-wrench" style="float: left;"></span>\ <span id="settings_close" class="ui-icon ui-icon-closethick" title="Click to hide preferences" style="float: right; cursor: pointer; display: block;"\></span>\ <span style="margin:3px">Settings (version ' + microVersion + ')</span>\ </div>\ <div id="script_settings"><ul></ul></div>\ <div id="account_settings">\ <div id="main_tabs"><ul></ul></div></div>\ <div id="account_info">\ <div id="info_tabs"><ul></ul></div></div>\ <div id="char_settings"></div>\ </div>'); // Add open settings button to page $("body").append('<div id="settingsButton"><span class="ui-icon ui-icon-wrench" title="Click to show preferences" style="cursor: pointer; display: block;"></span></div>'); $("#settingsPanel").hide(); $("#settingsButton").click(function() { $("#settingsButton").hide(); $("#pauseButton").hide(); $("#manualButton").hide(); $("#settingsPanel").show(); }); $("body").append(audioFile()); // Add pause button to page $("body").append('<div id="pauseButton"></div>'); displayPause(); $("#pauseButton").click( function () { PauseSettings(); }); // Add manual button to page $("body").append('<div id="manualButton"></div>'); displayManual(); $("#manualButton").click( function () { ManualSettings(); }); // Add revisit all chars button to page $("body").append('<div id="revisitButton"><span class="ui-icon ui-icon-arrowrefresh-1-e" title="Click to reprocess all chars" style="cursor: pointer; display: block;"></span></div>'); $("#revisitButton").click(function() { charNamesList.forEach(function (charName, idx) { chartimers[idx] = null; charStatisticsList[charName].general.nextTask = null; GM_setValue("statistics__char__" + charName + "@" + loggedAccount , JSON.stringify(charStatisticsList[charName])); }); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); // Add info pane $("body").append("<div id='prinfopane' class='header-newrelease'>"); $('#update-content-inventory-bags-0 .bag-header').waitUntilExists(function() { if ($('#update-content-inventory-bags-0 .bag-header div').length && !$('#update-content-inventory-bags-0 .bag-header div.autovendor').length) { $('#update-content-inventory-bags-0 .bag-header').append('<div class="input-field button light autovendor"><div class="input-bg-left"></div><div class="input-bg-mid"></div><div class="input-bg-right"></div><button id="nwprofs-autovendor">Auto Vendor</button></div>'); $("button#nwprofs-autovendor").on("click", vendorJunk); } }); $("#settings_close,settings_cancel").click(function() { $("#settingsButton").show(); $("#pauseButton").show(); $("#manualButton").show(); $("#settingsPanel").hide(); }); //$('#script_settings').html(''); var tab = addTab("#script_settings", tr('tab.scriptSettings')); addInputsUL(tab, 'script', 'main'); tab = addTab("#script_settings", tr('tab.advanced')); var thtml = "<button id='reset_settings_btn'>Reset ALL Settings</button><br /><br />"; thtml += "Must be logged in and at the correct character to list it's items.<br />"; thtml += "<button id='list_inventory_btn'>List Inventory</button><br /><br />"; thtml += "List settings (display all the configuration and obscure char names to char 1,2... and banker)<br />"; thtml += "<button id='list_settings_btn'>Dump settings </button><br /><br />"; tab.html(thtml); $('#reset_settings_btn').button(); $('#reset_settings_btn').click(function() { window.setTimeout(function() { GM_setValue("settings__char__" + c_name + "@" + loggedAccount, JSON.stringify(charSettingsList[c_name])); console.log("Saved char_task setting: " + scope + "." + group + "." + name + "." + sub_name + " For: " + c_name); var keys = GM_listValues(); for (i = 0; i < keys.length; i++) { var key = keys[i]; GM_deleteValue(key); } GM_setValue("script_version", scriptVersion); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }, 0); }); $('#list_inventory_btn').button(); $('#list_inventory_btn').click(function() { var _inventory; try { _inventory = client.dataModel.model.ent.main.inventory; } catch (e) { var str = "Inventory could not be loaded, make sure you are logged in and at the correct character." $('<div id="dialog-error-inventory" title="Error loading inventory">' + str + '</div>').dialog({ resizable: true, width: 500, modal: false, }); return; } var inv_tbl_head = "<table><tr><th>Slot #</th><th>Qty</th><th>Item Name</th><th>Rarity</th><th>Bound</th></tr>"; var str = ''; var slotCnt = 0; _inventory.playerbags.forEach(function (bag) { str += '<div>' + bag.name + '</div>'; str += inv_tbl_head; bag.slots.forEach( function (slot, slotNum) { if (!slot) return; slotCnt++; str += '<tr><td>' + slotNum + '</td><td>' + slot.count + '</td><td class=" rarity_' + slot.rarity + '">' + slot.name + '</td><td>' + slot.rarity + '</td><td>' + (slot.bound || slot.boundtoaccount) + '</td></tr>'; }); str += '</table><br/>'; }); _inventory.bags.filter(function(bag) { return (["CraftingResources", "Overflow", "CraftingInventory", "Bank"].indexOf(bag.bagid) != -1); }) .forEach(function(bag) { str += '<div>' + bag.bagid + '</div>'; str += inv_tbl_head; bag.slots.forEach( function (slot, slotNum) { if (!slot) return; str += '<tr><td>' + slotNum + '</td><td>' + slot.count + '</td><td class=" rarity_' + slot.rarity + '">' + slot.name + '</td><td>' + slot.rarity + '</td><td>' + (slot.bound || slot.boundtoaccount) + '</td></tr>'; }); str += '</table><br />'; }); $('<div id="dialog-inventory" title="Inventory listing">' + str + '</div>').dialog({ resizable: true, width: 550, height: 550, modal: false, }); }); $('#list_settings_btn').button(); $('#list_settings_btn').click(function() { var str = 'Script Settings (version ' + microVersion + ')\n'; var tempObj; tempObj = $.extend(true, {}, scriptSettings); tempObj.autoLoginAccount = ""; tempObj.autoLoginPassword = ""; str += '' + JSON.stringify(tempObj,null,4) + '\n'; str += 'Account Settings\n'; tempObj = $.extend(true, {}, accountSettings); if (accountSettings.consolidationSettings.bankCharName) { var bankIndex = charNamesList.indexOf(accountSettings.consolidationSettings.bankCharName); if (bankIndex == -1) str += "Bank set but not found in charNamesList\n"; else str += "Bank set and found at index:" + bankIndex + "\n"; tempObj.consolidationSettings.bankCharName = "Char " + bankIndex; } str += '' + JSON.stringify(tempObj,null,4) + '\n'; //str += '<pre>' + JSON.stringify(tempObj,null,4) + '</pre>'; str += 'Char Settings\n'; charNamesList.forEach(function (charName, idx){ tempObj = $.extend(true, {}, charSettingsList[charName]); str += 'Char ' + idx + '\n'; tempObj.charName = "Char " + idx; str += '' + JSON.stringify(tempObj,null,4) + '\n'; }) $('<div id="dialog-settings" title="Settings listing"><textarea style=" width: 98%; height: 98%;">' + str + '</textarea></div>').dialog({ resizable: true, width: 550, height: 750, modal: false, }); }); // Custom profiles tab = addTab("#script_settings", tr('tab.customProfiles')); var temp_html = ''; temp_html += '<div><label class="customProfiles">Task name: </label><select class=" custom_input customProfiles " id="custom_profiles_taskname">'; tasklist.forEach(function(task) { if (!task.taskActive) return; temp_html += '<option value="' + task.taskListName + '">' + task.taskListName + '</option>'; }) temp_html += '</select>'; temp_html += '<label class="customProfiles">Base Profile: </label><select class=" custom_input customProfiles " id="custom__profiles__baseprofile"></select>'; temp_html += '<button id="custom__profiles__viewbase_btn"></button>'; temp_html += '</div>'; temp_html += 'Input must be valid JSON: double quotes on property names & no trailing commas. <br /> Use any online validator to easily find errors. <br /> like: http://jsonformatter.curiousconcept.com/ <br /> http://json.parser.online.fr/'; temp_html += '<div><textarea id="custom_profile_textarea" class=" custom_input customProfiles ">'; temp_html += '{\n "profileName": "Example",\n "isProfileActive": true,\n "level": {\n "0": ["Alchemy_Tier0_Intro_1"],\n "1": ["Alchemy_Tier1_Refine_Basic", "Alchemy_Tier1_Gather_Components"]\n }\n}'; temp_html += '</textarea></div>'; temp_html += '<div><button id="custom__profiles__import_btn">Import</button></div>'; temp_html += '<table><tr><th>#</th><th>Task Name</th><th>Base Profile</th><th>Profile Name</th><th><th></tr>'; customProfiles.forEach(function (cProfile, idx) { temp_html += '<tr><td>' + (idx+1) + '</td>'; temp_html += '<td>' + cProfile.taskName + '</td>'; temp_html += '<td>' + cProfile.baseProfile + '</td>'; if (typeof cProfile.profile === 'object') temp_html += '<td>' + cProfile.profile.profileName + '</td>'; temp_html += '<td><button class="custom_profiles_view" value=' + idx + '></button><button class="custom_profiles_delete" value=' + idx + '></button></td></tr>'; }); temp_html += '</table>'; tab.html(temp_html); $( ".custom_profiles_view" ).button({ icons: { primary: "ui-icon-zoomin" }, text: false }); $( ".custom_profiles_view" ).click( function(e) { var pidx = $(this).val(); var str = "Task name : " + customProfiles[pidx].taskName + "\n"; str += "Base Profile : " + customProfiles[pidx].baseProfile + "\n" str += "Profile : \n\n"; str += JSON.stringify(customProfiles[pidx].profile,null,4); $('<div id="dialog-display-custom-profile" title="Custom profile"><textarea style=" width: 98%; height: 98%;">' + str + '</textarea></div>').dialog({ resizable: true, width: 550, height: 750, modal: false, }); }); $( ".custom_profiles_delete" ).button({ icons: { primary: "ui-icon-trash" }, text: false }); $( ".custom_profiles_delete" ).click( function(e) { var pidx = $(this).val(); customProfiles.splice(pidx,1); GM_setValue("custom_profiles", JSON.stringify(customProfiles)); console.log('Deleted custom profile ' + pidx); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); // Set up the advanced slot selects $("#custom_profiles_taskname").change(function(e) { var _taskname = $(this).val(); var _profiles = tasklist.filter(function(task) { return task.taskListName == _taskname; })[0].profiles.filter(function(profile) { return profile.isProfileActive }); var profileSelect = $("#custom__profiles__baseprofile").html(""); profileSelect.append($("<option />").val(null).text("new")); _profiles.forEach(function(profile) { profileSelect.append($("<option />").val(profile.profileName).text(profile.profileName)); }); }); $("#custom_profiles_taskname").change(); $('#custom__profiles__viewbase_btn').button({ icons: { primary: "ui-icon-zoomin" }, text: false }); $('#custom__profiles__viewbase_btn').click(function() { var _taskName = $("#custom_profiles_taskname").val(); var _baseProfile = $("#custom__profiles__baseprofile").val(); var _profiles = tasklist.filter(function(task) { return task.taskListName == _taskName; })[0].profiles.filter(function(profile) { return profile.profileName === _baseProfile; }); var str = JSON.stringify(_profiles,null,4); $('<div id="dialog-display-profile" title="Profile"><textarea style=" width: 98%; height: 98%;">' + str + '</textarea></div>').dialog({ resizable: true, width: 550, height: 750, modal: false, }); }); $('#custom__profiles__import_btn').button(); $('#custom__profiles__import_btn').click(function() { window.setTimeout(function() { var taskName = $("#custom_profiles_taskname").val(); var baseProfile = $("#custom__profiles__baseprofile").val(); var profile; try { profile = JSON.parse($('#custom_profile_textarea').val()); } catch (e) { alert("Failed to parse custom profile. JSON not valid."); return; } customProfiles.push({ taskName: taskName, baseProfile: baseProfile, profile: profile }); GM_setValue("custom_profiles", JSON.stringify(customProfiles)); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }, 0); }); // Tracked resources tab tab = addTab("#script_settings", tr('tab.trackedResources')); var temp_html = 'Insert human readable resource name and NeverWinter gateway internal resource name (from Inventory Listing)'; temp_html += '<div class="customResources"><label>Resource name: </label>'; temp_html += '<input type="text" name="" id="custom_resource_fname" \>'; temp_html += '<label>Inventory name: </label>'; temp_html += '<input type="text" name="" id="custom_resource_name" \>'; temp_html += '<br />' temp_html += '<input type="checkbox" name="" id="custom_resource_countbank" \><label>Count in bank</label>'; temp_html += '<input type="checkbox" name="" id="custom_resource_unbound" checked="checked" \><label>unbound </label>'; temp_html += '<input type="checkbox" name="" id="custom_resource_btc" checked="checked" \><label>BtC </label>'; temp_html += '<input type="checkbox" name="" id="custom_resource_bta" checked="checked" \><label>BtA </label>'; temp_html += '<button id="custom_resources_add_btn">Add</button>'; temp_html += '</div>'; temp_html += '<table><tr><th>#</th><th>Resource Name</th><th>bank</th><th>unbound</th><th>BtC</th><th>BtA</th><th><th></tr>'; trackResources.forEach(function (trRes, idx) { temp_html += '<tr><td>' + (idx+1) + '</td>'; temp_html += '<td>' + trRes.fname + '</td>'; temp_html += '<td><span class=" ui-icon ' + (trRes.bank ? 'ui-icon-check' : 'ui-icon-close') + '"></span></td>'; temp_html += '<td><span class=" ui-icon ' + (trRes.unbound ? 'ui-icon-check' : 'ui-icon-close') + '"></span></td>'; temp_html += '<td><span class=" ui-icon ' + (trRes.btc ? 'ui-icon-check' : 'ui-icon-close') + '"></span></td>'; temp_html += '<td><span class=" ui-icon ' + (trRes.bta ? 'ui-icon-check' : 'ui-icon-close') + '"></span></td>'; temp_html += '<td><button class="custom_resources_delete" value=' + idx + '></button></td></tr>'; }); temp_html += '</table><br /><button id="custom_resources_reset">Reset to default</button>'; tab.html(temp_html); $( ".custom_resources_delete" ).button({ icons: { primary: "ui-icon-trash" }, text: false }); $( ".custom_resources_delete" ).click( function(e) { if ( !loggedAccount ) { var str = "Tracked resource could not be removed, make sure you are logged in."; $('<div id="dialog-error-inventory" title="Error deleting tracked resource">' + str + '</div>').dialog({ resizable: true, width: 500, modal: false, }); return; } var pidx = $(this).val(); trackResources.splice(pidx,1); GM_setValue("tracked_resources", JSON.stringify(trackResources)); charNamesList.forEach( function (charName) { charStatisticsList[charName].trackedResources.splice(pidx, 1); GM_setValue("statistics__char__" + charName + "@" + loggedAccount , JSON.stringify(charStatisticsList[charName])); }); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); $( "#custom_resources_reset" ).button(); $( "#custom_resources_reset" ).click( function(e) { if ( !loggedAccount ) { var str = "Tracked resource could not be removed, make sure you are logged in."; $('<div id="dialog-error-inventory" title="Error deleting tracked resource">' + str + '</div>').dialog({ resizable: true, width: 500, modal: false, }); return; } GM_deleteValue("tracked_resources"); charNamesList.forEach( function (charName) { charStatisticsList[charName].trackedResources = []; GM_setValue("statistics__char__" + charName + "@" + loggedAccount , JSON.stringify(charStatisticsList[charName])); }); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); $('#custom_resources_add_btn').button(); $('#custom_resources_add_btn').click( function (e) { var _fname = $("#custom_resource_fname").val(); var _name = $("#custom_resource_name").val(); var _bank = $("#custom_resource_countbank").prop('checked'); var _unbound = $("#custom_resource_unbound").prop('checked'); var _btc = $("#custom_resource_btc").prop('checked'); var _bta = $("#custom_resource_bta").prop('checked'); if ( _fname.length == 0 || _name.length == 0) { var str = "Tracked resource could not be added. You have to enter both values!"; $('<div id="dialog-error-inventory" title="Error adding tracked resource">' + str + '</div>').dialog({ resizable: true, width: 500, modal: false, }); return; } trackResources.push({ fname: _fname, name: _name, bank: _bank, unbound: _unbound, btc: _btc, bta: _bta }); GM_setValue("tracked_resources", JSON.stringify(trackResources)); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); tab = addTab("#script_settings", tr('tab.manualSettings')); temp_html = '<p>In manual mode the script will stop when encountering a Leadership task.</p><br />'; temp_html += '<p>You will be notified with a text message and a sound so you can start a Leadership task from within the game. '; temp_html += 'After a while the script will go ahead and continue looking for (non-Leadership) tasks for that slot.</p><br />'; temp_html += '<p>There are two buttons on the notification: "Ignore" tells the script to ignore Leadership and assign another (non-leadership) task. '; temp_html += '"Done" tells it to re-scan the tasks after you manually assigned a Leadership task.</p><br />'; temp_html += '<p>This mode is enabled and disabled with the button next to the pause button.<p><br />'; temp_html += '<p><i>Note:</i> For this mode to work, Leadership has to have a higher priority than other professions. If the script finds any non-Leadership task to start, it will do so.</p><br /><br />'; tab.html(temp_html); addInputsUL(tab, 'script', 'manual'); $("#script_settings").tabs({ active: false, collapsible: true }); setEventHandlers = true; } // Refresh is needed / Loading all the info (account, statistics and chars) if (UIaccount != loggedAccount) { UIaccount = loggedAccount; var tabs = { main: tr('tab.general'), prof: tr('tab.professions'), vend: tr('tab.vendor'), bank: tr('tab.consolidation') }; for (var key in tabs) { var temp_tab = addTab("#main_tabs", tabs[key]); addInputsUL(temp_tab, 'account', key); } var settings_copy_tab = addTab("#main_tabs", tr('tab.copySettings')); $("div#main_tabs").tabs({ active: false, collapsible: true }); // Settings copy Tab var temp_html = ''; temp_html += '<div><label class="">Copy settings from: </label><select class=" custom_input " id="copy_settings_from">'; charNamesList.forEach( function (charName) { temp_html += '<option value="' + charName + '">' + charName + '</option>'; }) temp_html += '</select></div>'; temp_html += '<div><label class="">Copy settings to: (multiple select by holding ctrl/shift)</label></div><div><select multiple="multiple" class=" custom_input " id="copy_settings_to">'; charNamesList.forEach( function (charName) { temp_html += '<option value="' + charName + '">' + charName + '</option>'; }) temp_html += '</select></div><div><button id="copy_settings_button" class="" value="">copy</button></div>'; settings_copy_tab.html(temp_html); $( "#copy_settings_button" ).button(); $( "#copy_settings_button" ).click( function(e) { var _from = $("#copy_settings_from").val(); var _fromSettings = charSettingsList[_from]; if (!_fromSettings) return; var _to = $("#copy_settings_to").val(); _to.forEach(function (toName){ if (charNamesList.indexOf(toName) == -1) return; var newSettings = $.extend(true, {}, _fromSettings); newSettings.charName = toName; charSettingsList[toName] = newSettings; GM_setValue("settings__char__" + toName + "@" + loggedAccount, JSON.stringify(newSettings)); console.log("Copied settings from: ", _from, " to: ", toName); }) window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); //Statisitcs Tabs var temp_tab = addTab("#info_tabs", tr('tab.counters')); temp_tab.append("<div id='rcounters'></div>"); temp_tab = addTab("#info_tabs", tr('tab.refine_hist')); temp_tab.append("<div id='refine_hist'></div>"); temp_tab = addTab("#info_tabs", tr('tab.visits')); temp_tab.append("<div id='sca_v'></div>"); temp_tab = addTab("#info_tabs", tr('tab.workers')); temp_tab.append("<div id='worker_overview'></div>"); temp_tab = addTab("#info_tabs", tr('tab.tools')); temp_tab.append("<div id='tools_overview'></div>"); temp_tab = addTab("#info_tabs", tr('tab.resources')); temp_tab.append("<div id='resource_tracker'></div>"); temp_tab = addTab("#info_tabs", tr('tab.levels')); temp_tab.append("<div id='profession_levels'></div>"); temp_tab = addTab("#info_tabs", tr('tab.slots')); temp_tab.append("<div id='slot_tracker'></div>"); $("#info_tabs").tabs({ active: false, collapsible: true }); // Adding per char settings UI var wrp = $('<div id="charSettingsAccordion">'); $("#char_settings").append(wrp); charNamesList.forEach( function(charName, idx) { if (charSettingsList[charName].general.active) { wrp.append('<h3>' + charName + '</h3>'); } else { wrp.append("<h3 class='inactive'>" + charName + '</h3>'); } var wrp2 = $('<div id="charContainer' + idx + '">'); wrp.append(wrp2); addInputsUL(wrp2[0], 'char', 'main_not_tab', charName); var char_tabs = $('<div class="charSettingsTabs" id="char_tabs_' + idx + '"><ul></ul></div>'); wrp2.append(char_tabs); var task_tab = addTab(char_tabs[0], "Tasks"); // Creating the Tasks custom tab var tableHTML = $('<table><thead><tr><th>Task name</th><th># of slots</th><th>profile</th><th>priority</th><th>optionals</th><th>gond</th><th>stop at lvl</th></tr></thead><tbody>'); var _slotOptions = []; for (var i = 0; i < 10; i++) _slotOptions.push({ name: i, value: i }); var _priorityOptions = [{name:'high',value:0},{name:'medium',value:1},{name:'low',value:2}]; var _stopTaskAtLevelOptions = []; _stopTaskAtLevelOptions.push({name: 'none', value: 0}); for (var i = 1; i < 26; i++) _stopTaskAtLevelOptions.push({name: i, value: i}); var _optPrioOptions = [{name:"Don\'t fill",value:-1}, {name:'Quality',value:0},{name:'Speed',value:1}, {name:'Auto Lead',value:2}, {name:'Only Workers H->L',value:3}, {name:'Only Workers L->H',value:4}, {name:'Tools Only',value:5}, {name:'Purple',value:6}, {name:'Blue',value:7}, {name:'Green',value:8}, {name:'White',value:9}]; tasklist.forEach(function(task) { if (!task.taskActive) return; var _profileNames = []; task.profiles.forEach(function(profile) { if (profile.isProfileActive) _profileNames.push({ name: profile.profileName, value: profile.profileName }); }); var _slots = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'taskSlots', opts: _slotOptions ,title: task.taskListName, type: 'select', pane: 'tasks1', tooltip: 'Number of slots to assign to ' + task.taskListName}; var _profile = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'taskProfile', opts: _profileNames ,title: task.taskListName, type: 'select', pane: 'tasks1', tooltip: ''}; var _priority = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'taskPriority', opts: _priorityOptions ,title: task.taskListName, type: 'select', pane: 'tasks1', tooltip: ''}; var _optPrio = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'optPrio', opts: _optPrioOptions,title: task.taskListName, type: 'select', pane: 'tasks1', tooltip: ''}; var _useGond = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'useGond', title: task.taskListName, type: 'checkbox', pane: 'tasks1', tooltip: ''}; var _stop = {scope: 'char_task', group: 'taskListSettings', name: task.taskListName, sub_name: 'stopTaskAtLevel', opts: _stopTaskAtLevelOptions ,title: task.taskListName, type: 'select', pane: 'tasks1', tooltip: ''}; var _slt = createInput(_slots, charName, 'settingsInput', 'settingsLabel settingsTaskName'); var _prf = createInput(_profile, charName, 'settingsInput profileInput', 'settingsLabel'); var _pr = createInput(_priority, charName, 'settingsInput', 'settingsLabel'); var _optp = createInput(_optPrio, charName, 'settingsInput', 'settingsLabel'); var _gnd = createInput(_useGond, charName, 'settingsInput', 'settingsLabel'); var _stp = createInput(_stop, charName, 'settingsInput', 'settingsLabel'); var tr = $("<tr>"); $("<td>").append(_slt.label).appendTo(tr); $("<td>").append(_slt.input).appendTo(tr); $("<td>").append(_prf.input).appendTo(tr); $("<td>").append(_pr.input).appendTo(tr); $("<td>").append(_optp.input).appendTo(tr); $("<td>").append(_gnd.input).appendTo(tr); $("<td>").append(_stp.input).appendTo(tr); tr.appendTo(tableHTML); }); task_tab.append(tableHTML); // Manual Slots allocation tab var task2_tab = addTab(char_tabs[0], "Per-slot Tasks"); var tableHTML2 = $('<table><thead><tr><th>Slot #</th><th>Profession</th><th>Profile</th><th>Optionals</th><th>Gond</th></tr></thead><tbody>'); var taskOpts = []; tasklist.forEach(function(task) { if (!task.taskActive) return; taskOpts.push({ name: task.taskListName, value: task.taskListName }); }) function fillProfile(taskName) { var _profiles = tasklist.filter(function(task) { return task.taskListName == taskName; })[0].profiles.filter(function(profile) { return profile.isProfileActive }); var options = []; _profiles.forEach(function(profile) { options.push({ name: profile.profileName, value: profile.profileName }); }); return options; } // 9 slots for (var j = 0; j < 9; j++) { var _tasks = {scope: 'char_task', group: 'taskListSettingsManual', name: j, sub_name: 'Profession', opts: taskOpts ,title: 'Assign to slot #' +(j+1), type: 'select', pane: 'tasks2', tooltip: '', onchange: function (newValue, elm) { var profileId = $(elm).attr('id').split('__'); profileId[profileId.length-1] = 'Profile'; profileId = profileId.join('__'); var profileSelect = $("[id='" + profileId + "']").empty(); fillProfile(newValue).forEach(function(option) { profileSelect.append($("<option />").val(option.value).text(option.name)); }); profileSelect.change(); } }; var _tsk = createInput(_tasks, charName, 'settingsInput taskListSettingsManual taskListSettingsManualTask', 'settingsLabel'); var _profile = {scope: 'char_task', group: 'taskListSettingsManual', name: j, sub_name: 'Profile', opts: fillProfile($(_tsk.input).val()) ,title: '', type: 'select', pane: 'tasks2', tooltip: ''}; var _prf = createInput(_profile, charName, 'settingsInput taskListSettingsManual taskListSettingsManualProfile', 'settingsLabel'); var _optPrio = {scope: 'char_task', group: 'taskListSettingsManual', name: j, sub_name: 'optPrio', opts: _optPrioOptions, title: '', type: 'select', pane: 'tasks2', tooltip: ''}; var _useGond = {scope: 'char_task', group: 'taskListSettingsManual', name: j, sub_name: 'useGond', title: '', type: 'checkbox', pane: 'tasks2', tooltip: ''}; var _optp = createInput(_optPrio, charName, 'settingsInput', 'settingsLabel'); var _gnd = createInput(_useGond, charName, 'settingsInput', 'settingsLabel'); var tr = $("<tr>"); //$("<td>").append(_slt.label).appendTo(tr); $("<td>").append(_tsk.label).appendTo(tr); $("<td>").append(_tsk.input).appendTo(tr); $("<td>").append(_prf.input).appendTo(tr); $("<td>").append(_optp.input).appendTo(tr); $("<td>").append(_gnd.input).appendTo(tr); tr.appendTo(tableHTML2); } task2_tab.append(tableHTML2); // Char settings tabs var tabs_c = { main: 'General settings', prof: 'Professions', vend: 'Vendor options', bank: 'AD Consolidation' }; for (var key in tabs_c) { var temp_tab = addTab(char_tabs[0], tabs_c[key]); addInputsUL(temp_tab, 'char', key, charName); } }); $("#charSettingsAccordion").accordion({ heightStyle: "content", autoHeight: false, clearStyle: true, active: false, collapsible: true, }); $(".charSettingsTabs").tabs(); setEventHandlers = true; updateCounters(); } // Adding the save events if (setEventHandlers) { $("#settingsPanel input[type='checkbox'], #settingsPanel select").not(".custom_input").unbind("change"); $("#settingsPanel input[type='checkbox'], #settingsPanel select").change(function (evt) { saveSetting(evt.target); }); $("#settingsPanel input[type='text'], #settingsPanel input[type='password']").not(".custom_input").unbind("input"); $("#settingsPanel input[type='text'], #settingsPanel input[type='password']").on('input', function (evt) { var value = $(evt.target).val(); setTimeout(function(value) { if ($(evt.target).val() !== value) return; saveSetting(evt.target); }, 1000, value); }); } function saveSetting(elm) { var scope = $(elm).data('scope'); var group = $(elm).data('group'); var name = $(elm).data('name'); var value; if ($(elm).prop('type') === 'checkbox') value = $(elm).prop('checked'); else value = $(elm).val(); var fun = $(elm).data('onchange'); if (typeof fun === 'function') { var retval = fun(value, elm); if (retval === false ) return; // Allowing the onchange function to stop the save } switch (scope) { case 'script': scriptSettings[group][name] = value; setTimeout(function() { GM_setValue("settings__script", JSON.stringify(scriptSettings)); console.log("Saved script setting: " + scope + "." + group + "." + name + " Value: " + value); $(elm).addClass("inputSaved"); setTimeout(function() { $(elm).removeClass("inputSaved"); },1500); }, 0); break; case 'account': accountSettings[group][name] = value; setTimeout(function() { GM_setValue("settings__account__" + loggedAccount, JSON.stringify(accountSettings)); console.log("Saved account setting: " + scope + "." + group + "." + name + " Value: " + value + " For: " + loggedAccount); $(elm).addClass("inputSaved"); setTimeout(function() { $(elm).removeClass("inputSaved"); },1500); }, 0); break; case 'char': var c_name = $(elm).data('charName'); if (c_name && charSettingsList[c_name]) { charSettingsList[c_name][group][name] = value; setTimeout(function() { GM_setValue("settings__char__" + c_name + "@" + loggedAccount, JSON.stringify(charSettingsList[c_name])); console.log("Saved char setting: " + scope + "." + group + "." + name + " Value: " + value + " For: " + c_name); $(elm).addClass("inputSaved"); setTimeout(function() { $(elm).removeClass("inputSaved"); },1500); }, 0); } break; case 'char_task': var sub_name = $(elm).data('sub_name'); var c_name = $(elm).data('charName'); if (c_name && charSettingsList[c_name]) { charSettingsList[c_name][group][name][sub_name] = value; setTimeout(function() { GM_setValue("settings__char__" + c_name + "@" + loggedAccount, JSON.stringify(charSettingsList[c_name])); console.log("Saved char_task setting: " + scope + "." + group + "." + name + "." + sub_name + " Value: " + value + " For: " + c_name); $(elm).addClass("inputSaved"); setTimeout(function() { $(elm).removeClass("inputSaved"); },1500); }, 0); } break; } } // Helper function to create input elements function createInput( settingsItem, charName , input_css_classes, label_css_classes) { var input; var label; var id_name; var value; switch (settingsItem.scope) { case 'script': value = scriptSettings[settingsItem.group][settingsItem.name]; id_name = "setting__script__" + settingsItem.group + "__" + settingsItem.name; break; case 'account': id_name = "setting__account__" + settingsItem.group + "__" + settingsItem.name; value = accountSettings[settingsItem.group][settingsItem.name]; break; case 'char': id_name = "setting__char__" + charName + "__" + settingsItem.group + "__" + settingsItem.name; value = charSettingsList[charName][settingsItem.group][settingsItem.name]; break; case 'char_task': id_name = "setting__char__" + charName + "__" + settingsItem.group + "__" + settingsItem.name+ "__" + settingsItem.sub_name; value = charSettingsList[charName][settingsItem.group][settingsItem.name][settingsItem.sub_name]; break; } switch (settingsItem.type) { case 'checkbox': case 'text': case 'password': input = $("<input type=\"" + settingsItem.type + "\" name=\"" + id_name + "\" id=\"" + id_name + "\" class=\"" + input_css_classes + "\" \>"); break; case 'select': input = $("<select name=\"" + id_name + "\" id=\"" + id_name + "\" class=\"" + input_css_classes + "\" >"); settingsItem.opts.forEach( function (option) { input.append($("<option value=\"" + option.value + "\">" + option.name + "</option>")); }); break; case 'void': break; default: break; } if (settingsItem.type == 'checkbox') input.prop('checked', value); else input.val(value); input.data('scope', settingsItem.scope); input.data('group', settingsItem.group); input.data('name', settingsItem.name); if (settingsItem.sub_name) input.data('sub_name', settingsItem.sub_name); if (charName) input.data('charName', charName); if (settingsItem.onchange) input.data('onchange', settingsItem.onchange); label = $('<label title="' + settingsItem.tooltip + '" class="' + label_css_classes + '" for="' + id_name + '">' + settingsItem.title + '</label>'); return { input: input, label: label }; } function addInputsUL(parentSelector, scope, pane, charName) { var settingListToAdd = settingnames.filter(function(element) { return (element.scope == scope && element.pane == pane); }); if (!charName) charName = ''; var ul = $("<ul></ul>"); settingListToAdd.forEach( function (setting) { var to_add = createInput(setting, charName, 'settingsInput', 'settingsLabel'); var li = $("<li>"); switch (setting.type) { case 'checkbox': li.append(to_add.input); li.append(to_add.label); break; case 'text': case 'password': case 'select': case 'void': li.append(to_add.label); li.append(to_add.input); break; } ul.append(li); }) $(parentSelector).append(ul); } function addTab(parentSelector, tabTitle, tabId) { if (!tabId) { var tabs_num = $(" > ul > li", parentSelector).length + 1; tabId = $(parentSelector).attr('id') + "_tab_" + tabs_num; } $(" > ul", parentSelector).append("<li><a href='#" + tabId + "'>" + tabTitle + "</a></li>"); var tab = $("<div id='" + tabId + "'></div>"); $(parentSelector).append(tab); return tab; } // Close the panel /* $("#settingsButton").show(); $("#pauseButton img").attr("src", (settings["paused"] ? image_play : image_pause)); $("#pauseButton img").attr("title", "Click to " + (settings["paused"] ? "resume" : "pause") + " task script"); $("#pauseButton").show(); $("#settingsPanel").hide(); */ } function displayPause() { if (scriptSettings.general.scriptPaused) { $('#pauseButton').html('<span class="ui-icon ui-icon-play" title="Click to resume task script" style="cursor: pointer; display: block;"></span>'); } else { $('#pauseButton').html('<span class="ui-icon ui-icon-pause" title="Click to pause task script" style="cursor: pointer; display: block;"></span>'); } } function PauseSettings(_action) { switch (_action) { case true: case "pause": scriptSettings.general.scriptPaused = true; break; case false: case 'unpause': scriptSettings.general.scriptPaused = false; break; default: scriptSettings.general.scriptPaused = !scriptSettings.general.scriptPaused; break; } setTimeout(function() { //console.log("Pause set to", scriptSettings.general.scriptPaused); GM_setValue("settings__script", JSON.stringify(scriptSettings)); }, 0); displayPause(); } function displayManual() { if (scriptSettings.general.leadershipMode) { $('#manualButton').html('<span class="ui-icon ui-icon-transfer-e-w" title="Click to disable manual leadership handling" style="cursor: pointer; display: block;"></span>'); } else { $('#manualButton').html('<span class="ui-icon ui-icon-person" title="Click to enable manual leadership handling" style="cursor: pointer; display: block;"></span>'); } } function ManualSettings() { charNamesList.forEach( function (charName, idx) { if (leadershipSlots[charName]) { chartimers[idx] = null; } }); scriptSettings.general.leadershipMode = !scriptSettings.general.leadershipMode; leadershipSlots = {}; setTimeout(function() { GM_setValue("settings__script", JSON.stringify(scriptSettings)); }, 0); displayManual(); if (waitingNextChar) { clearTimeout(timerHandle); timerHandle = window.setTimeout(function() { process(); }, delay.SHORT); } } function IgnoreButton(idx, done) { if (done) { chartimers[idx] = leadershipSlots[charNamesList[idx]] = null; } else { chartimers[idx] = leadershipSlots[charNamesList[idx]] = new Date(); } if (waitingNextChar) { clearTimeout(timerHandle); curCharNum = GM_setValue("curCharNum_" + loggedAccount, idx); timerHandle = window.setTimeout(function() { process(); }, delay.SHORT); } } function updateCounters() { function formatNum(num) { if ((num / 1000000) > 1) return ((num / 1000000).toFixed(1) + 'm'); if ((num / 1000) > 1) return ((num / 1000).toFixed(1) + 'k'); return Math.floor(num); } var total = [0, 0, 0, 0]; var html = '<table>'; html += "<tr><th>Character Name</th><th>#slots</th><th>R.Counter</th><th>~ad/h</th>"; html += "<th>RAD</th><th>AD</th><th>gold</th><th>rBI</th><th>BI</th><th>R.today<th></th></tr>"; charNamesList.forEach(function(charName) { var counterTime = (Date.now() - charStatisticsList[charName].general.refineCounterReset) / 1000 / 60 / 60; // in hours. var radh = 0; if (counterTime > 0) radh = charStatisticsList[charName].general.refineCounter / counterTime; var outdated = (charStatisticsList[charName].general.lastVisit < lastDailyResetTime); total[0] += charStatisticsList[charName].general.refineCounter; total[1] += charStatisticsList[charName].general.diamonds; total[2] += charStatisticsList[charName].general.gold; total[3] += outdated ? 0 : (charStatisticsList[charName].general.refined[0] | 0); html += "<tr>"; html += "<td>" + charName + "</td>"; html += "<td>" + charStatisticsList[charName].general.activeSlots + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.refineCounter) + "</td>"; html += "<td>" + formatNum(radh) + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.rad) + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.diamonds) + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.gold) + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.rBI) + "</td>"; html += "<td>" + formatNum(charStatisticsList[charName].general.BI) + "</td>"; html += "<td>" + (outdated ? "0*" : formatNum(charStatisticsList[charName].general.refined[0] | 0)) + "</td>"; //html += "<td>" + formatNum(charStatisticsList[charName].general.refineLimitLeft) + "</td>"; html += "</tr>"; }); html += "<tr class='totals'><td>Totals (without AD in ZAX):</td><td></td><td>" + formatNum(total[0]) + "</td><td></td>"; html += "<td></td><td>" + formatNum(total[1]) + "</td><td>" + formatNum(total[2]) + "</td>"; html += "<td></td><td></td><td>" + formatNum(total[3]) + "<td></td></tr>"; html += "</table>"; html += "*No info for this reset yet. <br />"; html += "<button>Reset Refined Counter</button>"; $('#rcounters').html(html); $('#rcounters button').button(); $('#rcounters button').click(function() { charNamesList.forEach(function(charName) { charStatisticsList[charName].general.refineCounter = 0; charStatisticsList[charName].general.refineCounterReset = Date.now(); // !! This can couse a freeze on slow computers. GM_setValue("statistics__char__" + charName + "@" + loggedAccount , JSON.stringify(charStatisticsList[charName])); }); updateCounters(); }); //refine_hist var total = []; var slotSum = 0; var html = '<table>'; html += "<tr><th>Character Name</th>" for (var i = 0; i < 8; i++) { html += "<th>" + (-1 * i) + "</th>"; total[i] = 0; } html += "<th>avg</th>" html += "<th>per slot</th>" html += "</tr>"; charNamesList.forEach(function(charName) { var outdated = (charStatisticsList[charName].general.lastVisit < lastDailyResetTime); html += "<tr>"; html += "<td>" + charName + "</td>"; html += "<td>" + (outdated ? "0*" : formatNum(charStatisticsList[charName].general.refined[0] | 0)) + "</td>"; var sum = 0; var cnt = 0; for (var i = 1; i < 8; i++) { var refined = charStatisticsList[charName].general.refined[i] | 0 sum += refined; if (refined) cnt++; html += "<td>" + formatNum(refined) + "</td>"; total[i] += refined; } html += "<td>" + formatNum(sum/cnt) + "</td>"; html += "<td>" + formatNum(sum / cnt / (charStatisticsList[charName].general.activeSlots)) + "</td>"; html += "</tr>"; total[0] += outdated ? 0 : charStatisticsList[charName].general.refined[0] | 0; slotSum += charStatisticsList[charName].general.activeSlots; }); html += "<tr class='totals'><td>Totals (without AD in ZAX):</td>"; var tsum = 0; var cnt = 0; for (var i = 1; i < 8; i++) { tsum += total[i]; if (total[i]) cnt++; } for (var i = 0; i < 8; i++) { html += "<td>" + formatNum(total[i]) + "</td>"; } html += "<td>" + formatNum(tsum/cnt) + "</td>"; html += "<td>" + formatNum(tsum / cnt / slotSum) + "</td>"; html += "</tr></table><br />"; html += "Total (1 - 7): " + formatNum(tsum); $('#refine_hist').html(html); // Worker tab update. html = '<table class="professionRanks">'; var temp = ""; html += "<tr><th>Char name</th>"; var options = ""; var workerTabSelects = ["Leadership", "Alchemy", "Jewelcrafting"]; $.each(charStatisticsList[charNamesList[0]].professions, function(profession) { options += "<option value='" + profession + "'>" + profession + "</option>"; }) for (var i = 0; i < 3; i++) { //saving current select values if ($('#setting__worker__tab__p' + i).val()) workerTabSelects[i] = $('#setting__worker__tab__p' + i).val(); html += "<th colspan=6>" + "<select name='setting__worker__tab__p" + i + "' id='setting__worker__tab__p" + i + "'>" + options + "</select></th>"; temp += "<th>p</th><th>b</th><th>g</th><th>t3</th><th>t2</th><th>t1</th>"; } html += "</tr><tr><th></th>" + temp + "</tr>"; charNamesList.forEach(function(charName) { temp = ""; html += "<tr><td rowspan=2>" + charName + "</td>"; for (var i = 0; i < 3; i++) { var list = charStatisticsList[charName].professions[workerTabSelects[i]]; for (var ix = 0; ix < 6; ix++) { html += "<td class='ranked'>" + $.trim(list.workersUsed[ix]) + "</td>"; temp += "<td class='ranked2'>" + $.trim(list.workersUnused[ix]) + "</td>"; }; } /* $.each(charStatisticsList[charName].workers, function (pf, list) { for (var ix = 0; ix < 6; ix++) { html += "<td class='ranked'>" + $.trim(list.used[ix]) + "</td>"; temp += "<td class='ranked2'>" + $.trim(list.unused[ix]) + "</td>"; }; }) */ html += "</tr><tr>" + temp + "</tr>"; }) html += "</table>"; $('#worker_overview').html(html); for (var i = 0; i < 3; i++) { $('#setting__worker__tab__p' + i).val(workerTabSelects[i]); $('#setting__worker__tab__p' + i).change(function() { updateCounters(); }); } // Tools tab update. html = '<table class="professionRanks">'; var temp = ""; html += "<tr><th>Char name</th>"; var options = ""; var toolsTabSelects = ["Crucible", "Mortar", "Philosophersstone", "Graver"]; $.each(charStatisticsList[charNamesList[0]].tools, function(tool) { options += "<option value='" + tool + "'>" + tool + "</option>"; }); for (var i = 0; i < 4; i++) { //saving current select values if ($('#setting__tools__tab__p' + i).val()) toolsTabSelects[i] = $('#setting__tools__tab__p' + i).val(); html += "<th colspan=4>" + "<select name='setting__tools__tab__p" + i + "' id='setting__tools__tab__p" + i + "'>" + options + "</select></th>"; temp += "<th>p</th><th>b</th><th>g</th><th>w</th>"; } html += "</tr><tr><th></th>" + temp + "</tr>"; charNamesList.forEach(function(charName) { temp = ""; html += "<tr><td rowspan=2>" + charName + "</td>"; for (var i = 0; i < 4; i++) { var list = charStatisticsList[charName].tools[toolsTabSelects[i]]; for (var ix = 0; ix < 4; ix++) { html += "<td class='tranked'>" + $.trim(list.used[ix]) + "</td>"; temp += "<td class='tranked2'>" + $.trim(list.unused[ix]) + "</td>"; }; } html += "</tr><tr>" + temp + "</tr>"; }) html += "</table>"; $('#tools_overview').html(html); for (var i = 0; i < 4; i++) { $('#setting__tools__tab__p' + i).val(toolsTabSelects[i]); $('#setting__tools__tab__p' + i).change(function() { updateCounters(); }); } // Resource tracker update. html = "<table class='withRotation'><tr><th class='rotate'><div><span>Character Number</div></span></th>"; html += "<th class='rotate'><div><span>Character Name</div></span></th>"; html += "<th class='rotate'><div><span>Overflow</div></span></th>"; html += "<th class='rotate'><div><span>Empty bag slots</div></span></th>"; html += "<th class='rotate'><div><span>Total bag slots</div></span></th>"; html += "<th class='rotate'><div><span>Empty resources slots</div></span></th>"; html += "<th class='rotate'><div><span>Celestials</div></span></th>"; html += "<th class='rotate'><div><span>Ardents</div></span></th>"; trackResources.forEach(function(item) { html += "<th class='rotate'><div><span>" + item.fname + "</div></span></th>"; }) var total = []; for (var i = 0; i < trackResources.length; i++) total[i] = 0; html += '</tr>'; var charNumPos = 1; var endhtml = ''; charNamesList.forEach(function(charName) { var css_class = ''; endhtml += '<tr><td>' + charNumPos++ + '</td><td>' + charName + '</td>'; css_class = (charStatisticsList[charName].general.overflow > 0) ? " warning1 " : ""; endhtml += '<td class=\"' + css_class + '\">' + charStatisticsList[charName].general.overflow + '</td>'; css_class = ((charStatisticsList[charName].general.emptyBagSlots / charStatisticsList[charName].general.bagSlots *100) < 5) ? " warning2 " : ""; endhtml += '<td class=\"' + css_class + '\">' + charStatisticsList[charName].general.emptyBagSlots + '</td>'; endhtml += '<td>' + charStatisticsList[charName].general.bagSlots + '</td>'; css_class = ((charStatisticsList[charName].general.emptyResourceSlots / charStatisticsList[charName].general.resourceSlots *100) < 10) ? " warning2 " : ""; css_class = ((charStatisticsList[charName].general.emptyResourceSlots / charStatisticsList[charName].general.resourceSlots *100) < 5) ? " warning1 " : css_class; endhtml += '<td class=\"' + css_class + '\">' + charStatisticsList[charName].general.emptyResourceSlots + '</td>'; css_class = (charStatisticsList[charName].general.celestial >= 11) ? " warning2 " : ""; css_class = (charStatisticsList[charName].general.celestial == 14) ? " warning1 " : css_class; endhtml += '<td class=\"' + css_class + '\">' + charStatisticsList[charName].general.celestial + '</td>'; css_class = (charStatisticsList[charName].general.ardent >= 270) ? " warning3 " : ""; css_class = (charStatisticsList[charName].general.ardent >= 360) ? " warning2 " : css_class; css_class = (charStatisticsList[charName].general.ardent >= 480) ? " warning1 " : css_class; endhtml += '<td class=\"' + css_class + '\">' + charStatisticsList[charName].general.ardent + '</td>'; charStatisticsList[charName].trackedResources.forEach(function(count, idx) { endhtml += '<td>' + count + '</td>'; total[idx] += count; }) endhtml += '</tr>'; }) endhtml += "</table>"; html += "<tr class=\"totals\"><td>" + --charNumPos + "</td><td>Totals:</td><td>--</td><td>--</td><td>--</td><td>--</td><td>--</td><td>--</td>"; for (var i = 0; i < total.length; i++) html += "<td>" + total[i] + "</td>"; html += "</tr>"; html += endhtml $('#resource_tracker').html(html); // 'profession_levels' tab html = '<table class="withRotation">'; html += "<tr><th class='rotate'><div><span>Character Name</div></span></th>"; html += "<th class='rotate'><div><span>#slots</div></span></th>"; $.each(charStatisticsList[charNamesList[0]].professions, function(profession) { html += "<th class='rotate'><div><span>" + profession + "</div></span></th>"; }); html += "</tr>"; charNamesList.forEach(function(charName) { html += "<tr>"; html += "<td>" + charName + "</td>"; html += "<td>" + charStatisticsList[charName].general.activeSlots + "</td>"; $.each(charStatisticsList[charName].professions, function(name, profData) { html += "<td>" + profData.level + "</td>"; }); html += "</tr>"; }); html += "</table>"; $('#profession_levels').html(html); // 'slot_tracker' tab html = '<table>'; html += "<tr><th>Character Name</th>"; for (var i = 0; i < 9; i++) { html += "<th> #" + (i + 1) + " </th>"; } html += "</tr>"; charNamesList.forEach(function(charName) { html += "<tr>"; html += "<td>" + charName + "</td>"; for (var i = 0; i < 9; i++) { var _slot = charStatisticsList[charName].slotUse[i]; html += "<td class=' slt_"+ $.trim(_slot).substring(0, 4) + "'>" + $.trim(_slot).substring(0, 4) + " </td>"; } html += "</tr>"; }); html += "</table>"; $('#slot_tracker').html(html); // Visit times and SCA tab html = '<table>'; html += "<tr><th>Character Name</th><th>Next Profession</th><th>Last SCA</th><th>Override</th></tr>"; charNamesList.forEach(function(charName, idx) { html += "<tr>"; html += "<td>" + charName + "</td>"; if (!chartimers[idx]) html += "<td>No data</td>"; else html += "<td><button class=' visitReset ' value=" + (idx + 1) + ">reset</button><span data-timer='" + chartimers[idx] + "' data-timer-length='2'></span></td>"; if (!charStatisticsList[charName].general.lastSCAVisit) html += "<td>No data</td>"; else html += "<td>" + (new Date(charStatisticsList[charName].general.lastSCAVisit)).toLocaleString() + "</td>"; if (charSettingsList[charName].general.overrideGlobalSettings) html += "<td><span class='ui-icon ui-icon-check '></span></td>"; else html += "<td></td>"; html += "</tr>"; }); html += "</table>"; html += "<div style='margin: 5px 0;'> Last SCA reset (test #1): " + (new Date(accountSettings.generalSettings.SCADailyReset)).toLocaleString() + "</div>"; html += "<div style='margin: 5px 0;'> Last SCA reset (test #2): " + (new Date(lastDailyResetTime)).toLocaleString() + "</div>"; $('#sca_v').html(html); $('#sca_v').append("<br /><br /><button id='settings_sca'>Cycle SCA</button>"); $('#sca_v').append(" <button id='reset_all_char_times_btn'>Reset All Visit Times</button>"); $('#settings_sca').button(); $("#settings_sca").click(function() { $("#settings_close").trigger("click"); unsafeWindow.location.hash = unsafeWindow.location.hash.replace(/\)\/.+/, ')' + "/adventures"); processSwordCoastDailies(); }); $('#reset_all_char_times_btn').button(); $("#reset_all_char_times_btn").click(function() { charNamesList.forEach(function (charName, idx) { chartimers[idx] = null; charStatisticsList[charName].general.nextTask = null; GM_setValue("statistics__char__" + charName + "@" + loggedAccount , JSON.stringify(charStatisticsList[charName])); }); window.setTimeout(function() { unsafeWindow.location.href = current_Gateway; }, 0); }); $('.visitReset').button(); $(".visitReset").click(function() { var value = $(this).val(); if (value) { console.log("Reseting for " + charNamesList[value-1]); chartimers[parseInt(value)-1] = null; updateCounters(); if (waitingNextChar) { clearTimeout(timerHandle); curCharNum = GM_setValue("curCharNum_" + loggedAccount, parseInt(value)-1); timerHandle = window.setTimeout(function() { process(); }, delay.SHORT); } } }); } function vendorJunk(evnt) { var _vendorItems = []; var _sellCount = 0; if (getSetting('vendorSettings', 'vendorInvocationBlessingsAll')) { _vendorItems[_vendorItems.length] = { pattern: /^Invocation_Random_Buff$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorKitsLimit')) { _vendorItems[_vendorItems.length] = { pattern: /^Item_Consumable_Skill/, limit: 50 }; } if (getSetting('vendorSettings', 'vendorAltarsLimit')) { _vendorItems[_vendorItems.length] = { pattern: /^Item_Portable_Altar$/, limit: 80 }; } if (getSetting('vendorSettings', 'vendorKitsAll')) { _vendorItems[_vendorItems.length] = { pattern: /^Item_Consumable_Skill/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorAltarsAll')) { _vendorItems[_vendorItems.length] = { pattern: /^Item_Portable_Altar(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorEnchR1')) { _vendorItems[_vendorItems.length] = { pattern: /^T1_Enchantment/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^T1_Runestone/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorEnchR2')) { _vendorItems[_vendorItems.length] = { pattern: /^T2_Enchantment/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^T2_Runestone/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorEnchR3')) { _vendorItems[_vendorItems.length] = { pattern: /^T3_Enchantment/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^T3_Runestone/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorEnchR4')) { _vendorItems[_vendorItems.length] = { pattern: /^T4_Enchantment/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^T4_Runestone/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorEnchR5')) { _vendorItems[_vendorItems.length] = { pattern: /^T5_Enchantment/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^T5_Runestone/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorLesserMarks')) { _vendorItems[_vendorItems.length] = { pattern: /^(Gem_Upgrade_Resource_R[1-2]|Artifact_Upgrade_Resource_R1_[A-Z])$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorPots1')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorPots2')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)_2(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorPots3')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)_3(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorPots4')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)_4(_Bound)?$/, limit: 0 }; } if(getSetting('vendorSettings', 'vendorPots5')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)_5(_Bound)?$/, limit: 0 }; } if(getSetting('vendorSettings', 'vendorPots6')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_(Tidespan|Force|Fortification|Reflexes|Accuracy|Rejuvenation)_6(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorHealingPots')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_Healing(_[1-5])?(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorHealingPotsAll')) { _vendorItems[_vendorItems.length] = { pattern: /^Potion_Healing(_[1-9])?(_Bound)?$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorJunk')) { _vendorItems[_vendorItems.length] = { pattern: /^Item_Snowworks_/, limit: 0 }; // Winter Festival fireworks small & large _vendorItems[_vendorItems.length] = { pattern: /^Item_Skylantern/, limit: 0 }; // Winter Festival skylantern _vendorItems[_vendorItems.length] = { pattern: /^Item_Partypopper/, limit: 0 }; // Party Poppers _vendorItems[_vendorItems.length] = { pattern: /^Item_Fireworks/, limit: 0 }; // Fireworks _vendorItems[_vendorItems.length] = { pattern: /^Object_Plate_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Decoration_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Gem_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Jewelry_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Mug_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Trinket_/, limit: 0 }; _vendorItems[_vendorItems.length] = { pattern: /^Object_Skill_/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorGreenUnidAll')) { _vendorItems[_vendorItems.length] = { pattern: /_Green_T[1-9]_Unid$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorBlueUnidAll')) { _vendorItems[_vendorItems.length] = { pattern: /_Blue_T[1-9]_Unid$/, limit: 0 }; } if (getSetting('vendorSettings', 'vendorProfResults')) { _vendorItems[_vendorItems.length] = { pattern: /^Crafted_(Jewelcrafting_Neck_Defense_3|Jewelcrafting_Waist_Defense_3|Jewelcrafting_T4_Neck_Base_3|Jewelcrafting_T4_Neck_Defense_3|Jewelcrafting_T4_Neck_Misc_3|Med_Armorsmithing_T3_Chain_Armor_Set_1|Med_Armorsmithing_T3_Chain_Pants2|Med_Armorsmithing_T3_Chain_Shirt2|Med_Armorsmithing_T3_Chain_Helm_Set_1|Med_Armorsmithing_T3_Chain_Pants|Med_Armorsmithing_T3_Chain_Boots_Set_1|Med_Armorsmithing_Pants_3|Med_Armorsmithing_Chain_Pants_3|Hvy_Armorsmithing_T3_Plate_Armor_Set_1|Hvy_Armorsmithing_T3_Plate_Pants2|Hvy_Armorsmithing_T3_Plate_Shirt2|Hvy_Armorsmithing_T3_Plate_Helm_Set_1|Hvy_Armorsmithing_T3_Plate_Boots_Set_1|Hvy_Armorsmithing_Pants_3|Leatherworking_T3_Leather_Armor_Set_1|Leatherworking_T3_Leather_Pants2|Leatherworking_T3_Leather_Shirt2|Leatherworking_T3_Leather_Helm_Set_1|Leatherworking_T3_Leather_Boots_Set_1|Leatherworking_Pants_3|Tailoring_T3_Cloth_Armor_Set_3|Tailoring_T3_Cloth_Armor_Set_2|Tailoring_T3_Cloth_Armor_Set_1|Tailoring_T3_Cloth_Pants2_Set2|Tailoring_T3_Cloth_Shirt2|Tailoring_T3_Cloth_Helm_Set_1|Tailoring_Pants_3|Artificing_T3_Pactblade_Temptation_5|Artificing_T3_Icon_Virtuous_5|Weaponsmithing_T3_Dagger_4)|^Potion_Unstable_([1-6])*$/, limit: 0 }; } if (_vendorItems.length > 0) { console.log("Attempting to vendor selected items..."); _sellCount = vendorItemsLimited(_vendorItems); if (_sellCount > 0 && !evnt) { var _sellWait = _sellCount * 1000; PauseSettings("pause"); window.setTimeout(function() { PauseSettings("unpause"); }, _sellWait); } } } function addTranslation() { var lang = GM_getValue('language', 'en'); translation = { 'currLang': lang, 'en': { 'translation.needed': 'translation needed', 'tab.scriptSettings': 'Script settings', 'tab.advanced': 'Advanced', 'tab.customProfiles': 'Custom profiles', 'tab.trackedResources': 'Tracked resources', 'tab.general': 'General settings', 'tab.manualSettings': 'Manual Leadership Mode', 'tab.professions': 'Professions', 'tab.vendor': 'Vendor options', 'tab.consolidation': 'AD Consolidation', 'tab.copySettings': 'Settings Copy', 'tab.other': 'Other', 'tab.counters': 'Refine Counters', 'tab.refine_hist': 'Refine-7', 'tab.visits': 'SCA & Visits', 'tab.workers': 'Workers', 'tab.tools': 'Tools', 'tab.resources': 'Resource Tracker', 'tab.levels': 'Prof levels', 'tab.slots': 'Slots', 'static.settings': 'Settings', 'button.save&apply': 'Save and Apply', 'button.close': 'Close', 'button.cycle': 'Cycle SCA', //'settings.main.paused': 'Pause Script', //'settings.main.paused.tooltip': 'Disable All Automation', 'settings.main.debug': 'Enable Debug', 'settings.main.debug.tooltip': 'Enable all debug output to console', 'settings.main.autoreload': 'Auto Reload', 'settings.main.autoreload.tooltip': 'Enabling this will reload the gateway periodically. (Ensure Auto Login is enabled)', 'settings.main.incdelay': 'Increase script delays by', 'settings.main.incdelay.tooltip': 'Increase the delays the script waits before attempting the actions.', 'settings.main.language': 'Script language', 'settings.main.language.tooltip': 'Set GUI language of this script (change requires reloading the page)', 'settings.main.autologin': 'Attempt to login automatically', 'settings.main.autologin.tooltip': 'Automatically attempt to login to the neverwinter gateway site', 'settings.main.nw_username': 'Neverwinter Username', 'settings.main.nw_username.tooltip': '', 'settings.main.nw_password': 'Neverwinter Password', 'settings.main.nw_password.tooltip': '', 'settings.main.savenexttime': 'Save next process times', 'settings.main.savenexttime.tooltip': 'Save the next proffesion times persistently', 'settings.general.openrewards': 'Open Reward Chests', 'settings.general.openrewards.tooltip': 'Enable opening of leadership chests on character switch', 'settings.general.opencelestial': 'Open Celestial Chests', 'settings.general.opencelestial.tooltip': 'Open Chests bought with Celestial Coins', 'settings.general.openInvocation': 'Open Invocation Rewards', 'settings.general.openInvocation.tooltip': 'Enable opening rewards from invocation', 'settings.general.openVIP': 'Open Account Bound VIP Rewards', 'settings.general.openVIP.tooltip': 'Enable opening account bound rewards from VIP', 'settings.general.keepOneUnopened': 'Keep one reward box unopened', 'settings.general.keepOneUnopened.tooltip': 'Used to reserve the slots for the reward boxes', 'settings.general.refinead': 'Refine AD', 'settings.general.refinead.tooltip': 'Enable refining of AD on character switch', 'settings.general.runSCA': 'Run SCA', 'settings.general.runSCA.tooltip': 'Running SCA adventures reward after professions', 'settings.profession.fillOptionals': 'Fill Optional Assets', 'settings.profession.fillOptionals.tooltip': 'Enable to include selecting the optional assets of tasks', 'settings.profession.autoPurchase': 'Auto Purchase Resources', 'settings.profession.autoPurchase.tooltip': 'Automatically purchase required resources from gateway shop (100 at a time)', 'settings.profession.trainAssets': 'Train Assets', 'settings.profession.trainAssets.tooltip': 'Enable training/upgrading of asset worker resources', 'settings.profession.spreadLeadership': 'Spread Asset allocation for leadership', 'settings.profession.spreadLeadership.tooltip': 'Try to spread and fill non-common assets and supplement with common if needed', 'settings.profession.stopNotLeadership': 'Stop NON-Leadership task at level: ', 'settings.profession.stopNotLeadership.tooltip': 'Block All professions except Leadership at level 20 or 25 and above. Make sure you have Leadership set.', 'settings.profession.stopAlchemyAt3': 'Stop Alchemy leveling at level 3', 'settings.profession.stopAlchemyAt3.tooltip': 'Block Alchemy tasks at level 3 and above. Make sure you have other tasks set.', 'settings.consolid.consolidate': 'Consolidate AD via ZAX', 'settings.consolid.consolidate.tooltip': 'Automatically attempt to post, cancel and withdraw AD via ZAX and consolidate to designated character', 'settings.consolid.bankerName': 'Character Name of Banker', 'settings.consolid.bankerName.tooltip': 'Enter name of the character to hold account AD', 'settings.consolid.minToTransfer': 'Min AD for Transfer', 'settings.consolid.minToTransfer.tooltip': 'Enter minimum AD limit for it to be considered for transfer off a character', 'settings.consolid.minCharBalance': 'Min Character balance', 'settings.consolid.minCharBalance.tooltip': 'Enter the amount of AD to always keep available on characters', 'settings.consolid.transferRate': 'AD per Zen Rate (in zen)', 'settings.consolid.transferRate.tooltip': 'Enter default rate to use for transferring through ZAX', }, 'pl': { 'translation.needed': 'wymagane tÅ‚umaczenie', 'tab.scriptSettings': 'Ustawienia skryptu', 'tab.advanced': 'Zaawansowane', 'tab.customProfiles': 'WÅ‚asne profile', 'tab.trackedResources': 'Åšledzone surowce', 'tab.general': 'Ogólne', 'tab.professions': 'Profesje', 'tab.vendor': 'Kupiec', 'tab.consolidation': 'Konsolidacja AD', 'tab.copySettings': 'Kopiuj ustawienia', 'tab.other': 'PozostaÅ‚e', 'tab.counters': 'Liczniki szlifowania', 'tab.visits': 'Nast.zadanie i SCA', 'tab.workers': 'Pracownicy', 'tab.tools': 'NarzÄ™dzia', 'tab.resources': 'Surowce', 'tab.levels': 'Poziomy prof.', 'tab.slots': 'Sloty', 'static.settings': 'Ustawienia', 'button.save&apply': 'Zapisz i zastosuj', 'button.close': 'Zamknij', 'button.cycle': 'Runda SCA', //'settings.main.paused': 'Zatrzymaj skrypt', //'settings.main.paused.tooltip': 'Wyłącz wszelkÄ… automatyzacjÄ™', 'settings.main.debug': 'Włącz debugowanie', 'settings.main.debug.tooltip': 'WyÅ›wietl wszystkie komunikaty na konsoli (Ctrl+Shift+i w Chrome/Chromium)', 'settings.main.autoreload': 'Automatyczne przeÅ‚adowanie', 'settings.main.autoreload.tooltip': 'Włączenie tej opcji powoduje okresowe przeÅ‚adowanie strony (Upewnij siÄ™, że Automatyczne logowanie jest włączone)', 'settings.main.incdelay': 'ZwiÄ™ksz opóżnienia skryptu o...', 'settings.main.incdelay.tooltip': 'ZwiÄ™kszenie opóźnieÅ„, gdy skrypt czeka przed próbÄ… dziaÅ‚ania (pomocne przy wolnych połączeniach).', 'settings.main.language': 'JÄ™zyk skryptu', 'settings.main.language.tooltip': 'JÄ™zyk interfejsu tego skryptu (zmiana wymaga przeÅ‚adowania strony)', 'settings.main.autologin': 'Próbuj logować automatycznie', 'settings.main.autologin.tooltip': 'Próbuj logować automatycznie do strony gateway', 'settings.main.nw_username': 'Nazwa użytkownika Neverwinter', 'settings.main.nw_username.tooltip': '', 'settings.main.nw_password': 'HasÅ‚o do Neverwinter', 'settings.main.nw_password.tooltip': '', 'settings.main.savenexttime': 'Zapisuj czas nastÄ™pnego zadania', 'settings.main.savenexttime.tooltip': 'Zapisuj czas nastÄ™pnego zadania w danych miÄ™dzysesyjnych', 'settings.general.openrewards': 'Otwieraj skrzynki', 'settings.general.openrewards.tooltip': 'Otwieraj skrzynki z zadaÅ„ Przywództwa przy zmianie postaci', 'settings.general.openInvocation': 'Otwieraj nagrody z inwokacji', 'settings.general.openInvocation.tooltip': 'Otwieraj nagrody z inwokacji - zajmujÄ… masÄ™ miejsca, bo siÄ™ nie łączÄ… w stosy', 'settings.general.openVIP': 'Otwórz rachunek Zwiazany Nagrody VIP', 'settings.general.openVIP.tooltip': 'Wlacz otwarcie konta nagrody zwiazane z VIP', 'settings.general.opencelestial': 'Otwieraj skrzynki za monety', 'settings.general.opencelestial.tooltip': 'Otwieraj skrzynki kupione za 13 monet z inwokacji', 'settings.general.keepOneUnopened': 'Pozostaw jednÄ… skrzynkÄ™ nieotwartÄ…', 'settings.general.keepOneUnopened.tooltip': 'Potrzebne do zarezerwowania miejsca na nagrody', 'settings.general.refinead': 'Szlifuj diamenty', 'settings.general.refinead.tooltip': 'Przy zmianie postaci szlifuj diamenty astralne jeÅ›li to możliwe', 'settings.general.runSCA': 'Uruchom Wybrzeże Mieczy', 'settings.general.runSCA.tooltip': 'Uruchom Wybrzeże Mieczy po wybraniu zadaÅ„ profesji', 'settings.profession.fillOptionals': 'WypeÅ‚niaj opcjonalnych pracowników', 'settings.profession.fillOptionals.tooltip': 'Pozwól na używanie wiÄ™kszej iloÅ›ci pracowników dla zadaÅ„, które na to pozwalajÄ…', 'settings.profession.autoPurchase': 'Autozakup surowców', 'settings.profession.autoPurchase.tooltip': 'Automatycznie kupuj wynagane surowce profesji ze sklepu (po 100 sztuk równoczeÅ›nie)', 'settings.profession.trainAssets': 'Trenuj pracowników', 'settings.profession.trainAssets.tooltip': 'Pozwól na trenowanie/ulepszanie zwykÅ‚ych pracowników', 'settings.profession.spreadLeadership': 'Inteligentny przydziaÅ‚ pracowników do Przywództwa', 'settings.profession.spreadLeadership.tooltip': 'Próbuje przydzielić jak najmniej zwykÅ‚ych pracowników do zadaÅ„ przywództwa', 'settings.profession.stopNotLeadership': 'Wstrzymaj profesje inne od Przywództwa na poziomie', 'settings.profession.stopNotLeadership.tooltip': 'Nie uruchamiaj zadaÅ„ profesji innej od Przywództwa po osiÄ…gniÄ™ciu poziomu. Upewnij siÄ™, ze masz ustawione Przywództwo.', 'settings.profession.stopAlchemyAt3': 'Wstrzymaj naukÄ™ Alchemii na poziomie 3', 'settings.profession.stopAlchemyAt3.tooltip': 'Wstrzymaj naukÄ™ Alchemii na poziomie 3 lub wyższym. Upewnij siÄ™, że masz ustawione inne profesje.', 'settings.consolid.consolidate': 'Konsoliduj AD przez ZAX', 'settings.consolid.consolidate.tooltip': 'Automatycznie próbuj wysyÅ‚ać Diamenty Astralne przez wymianÄ™ ZEN i wypÅ‚acać na jednej postaci', 'settings.consolid.bankerName': 'Nazwa Bankiera', 'settings.consolid.bankerName.tooltip': 'Wprowadź nazwÄ™ postaci, która ma zbierać wszystkie Diamenty Astralne konta', 'settings.consolid.minToTransfer': 'Min AD do transferowania', 'settings.consolid.minToTransfer.tooltip': 'Minimalna ilość Diamentów Astralnych, przy której nastÄ…pi próba przeniesienia do bankiera', 'settings.consolid.minCharBalance': 'Min AD do pozostawienia', 'settings.consolid.minCharBalance.tooltip': 'Minimalna ilość Diamentów Astralnych, które powinny pozostać na koncie postaci', 'settings.consolid.transferRate': 'Stawka AD za Zen', 'settings.consolid.transferRate.tooltip': 'DomyÅ›lna stawka Diamentów Astralnych za ZEN użyta do transferowania', }, 'fr': { 'translation.needed': 'traduction nécessaire', } }; } function tr(key) { var lang = translation['currLang']; if (translation['en'][key] === undefined) { console.log("translation: unknown key " + key); return "unknown key: " + key; } if (translation[lang][key] === undefined) { console.log('translation needed: lang: ' + lang + ", key: " + key); return '/-/ ' + translation['en'][key] + ' /-/'; } return translation[lang][key]; } /** Start, Helpers added by users. * Adds fetures, options to base script and can be easily removed if needed * Add description so anyone can see if they can use Function somewhere * Use "brackets" around function start and end //yourname */ //RottenMind, returns inventory space, use Inventory_bagspace(); gives current free bags slots, from MAC-NW function function Inventory_bagspace() { var _pbags = client.dataModel.model.ent.main.inventory.playerbags; var _bagUnused = 0; $.each(_pbags, function(bi, bag) { bag.slots.forEach(function(slot) { if (slot === null || !slot || slot === undefined) { _bagUnused++; } }); }); return _bagUnused; } //RottenMind /** End, Helpers added by users.*/ // Add the settings button and start a process timer addSettings(); timerHandle = window.setTimeout(function() { process(); }, delay.SHORT); })(); function workerDefinition() { return { // purple, blue, green, t3, t2, t1 "Leadership": ["Crafting_Asset_Craftsman_Leadership_T3_Epic", "Crafting_Asset_Craftsman_Leadership_T3_Rare", "Crafting_Asset_Craftsman_Leadership_T3_Uncommon", "Crafting_Asset_Craftsman_Leadership_T3_Common", "Crafting_Asset_Craftsman_Leadership_T2_Common", "Crafting_Asset_Craftsman_Leadership_T1_Common_1" ], "Alchemy": ["Asset_Craftsman_Alchemy_T3_Epic", "Asset_Craftsman_Alchemy_T3_Rare", "Asset_Craftsman_Alchemy_T3_Uncommon", "Asset_Craftsman_Alchemy_T3_Common", "Asset_Craftsman_Alchemy_T2_Common", "Asset_Craftsman_Alchemy_T1_Common" ], "Jewelcrafting": ["Crafting_Asset_Craftsman_Jewelcrafter_T3_Epic", "Crafting_Asset_Craftsman_Jewelcrafter_T3_Rare", "Crafting_Asset_Craftsman_Jewelcrafter_T3_Uncommon", "Crafting_Asset_Craftsman_Jewelcrafter_T3_Common", "Crafting_Asset_Craftsman_Jewelcrafter_T2_Common", "Crafting_Asset_Craftsman_Jewelcrafter_T1_Common" ], "Weaponsmithing": ["Crafting_Asset_Craftsman_Weaponsmith_T3_Epic", "Crafting_Asset_Craftsman_Weaponsmith_T3_Rare", "Crafting_Asset_Craftsman_Weaponsmith_T3_Uncommon", "Crafting_Asset_Craftsman_Weaponsmith_T3_Common", "Crafting_Asset_Craftsman_Weaponsmith_T2_Common", "Crafting_Asset_Craftsman_Weaponsmith_T1_Common" ], "Artificing": ["Crafting_Asset_Craftsman_Artificing_T3_Epic", "Crafting_Asset_Craftsman_Artificing_T3_Rare", "Crafting_Asset_Craftsman_Artificing_T3_Uncommon", "Crafting_Asset_Craftsman_Artificing_T3_Common", "Crafting_Asset_Craftsman_Artificing_T2_Common", "Crafting_Asset_Craftsman_Artificing_T1_Common" ], "Mailsmithing": ["Crafting_Asset_Craftsman_Armorsmithing_Med_T3_Epic", "Crafting_Asset_Craftsman_Armorsmithing_Med_T3_Rare", "Crafting_Asset_Craftsman_Armorsmithing_Med_T3_Uncommon", "Crafting_Asset_Craftsman_Armorsmithing_Med_T3_Common", "Crafting_Asset_Craftsman_Armorsmithing_Med_T2_Common", "Crafting_Asset_Craftsman_Armorsmithing_Med_T1_Common" ], "Platesmithing": ["Crafting_Asset_Craftsman_Armorsmithing_Hvy_T3_Epic", "Crafting_Asset_Craftsman_Armorsmithing_Hvy_T3_Rare", "Crafting_Asset_Craftsman_Armorsmithing_Hvy_T3_Uncommon", "Crafting_Asset_Craftsman_Armorsmithing_Hvy_T3_Common", "Crafting_Asset_Craftsman_Armorsmithing_Hvy_T2_Common", "Crafting_Asset_Craftsman_Armorsmithing_Hvy_T1_Common" ], "Leatherworking": ["Crafting_Asset_Craftsman_Leatherworking_T3_Epic", "Crafting_Asset_Craftsman_Leatherworking_T3_Rare", "Crafting_Asset_Craftsman_Leatherworking_T3_Uncommon", "Crafting_Asset_Craftsman_Leatherworking_T3_Common", "Crafting_Asset_Craftsman_Leatherworking_T2_Common", "Crafting_Asset_Craftsman_Leatherworking_T1_Common" ], "Tailoring": ["Crafting_Asset_Craftsman_Tailoring_T3_Epic", "Crafting_Asset_Craftsman_Tailoring_T3_Rare", "Crafting_Asset_Craftsman_Tailoring_T3_Uncommon", "Crafting_Asset_Craftsman_Tailoring_T3_Common", "Crafting_Asset_Craftsman_Tailoring_T2_Common", "Crafting_Asset_Craftsman_Tailoring_T1_Common" ], "Black Ice Shaping": ["Crafting_Asset_Craftsman_Blackice_T3_Epic", "Crafting_Asset_Craftsman_Blackice_T3_Rare", "Crafting_Asset_Craftsman_Blackice_T3_Uncommon", "Crafting_Asset_Craftsman_Blackice_T3_Common" ], /* "Winter Event": ["Crafting_Asset_Craftsman_Winter_Event_T1_Common"], "Siege Event": [], */ } } function toolListDefinition() { return { "Awl": ["Crafting_Asset_Tool_Awl_Epic", "Crafting_Asset_Tool_Awl_Rare", "Crafting_Asset_Tool_Awl_Uncommon", "Crafting_Asset_Tool_Awl_Common"], "Shears": ["Crafting_Asset_Tool_Shears_Epic", "Crafting_Asset_Tool_Shears_Rare", "Crafting_Asset_Tool_Shears_Uncommon", "Crafting_Asset_Tool_Shears_Common"], "Hammer": ["Crafting_Asset_Tool_Hammer_Epic", "Crafting_Asset_Tool_Hammer_Rare", "Crafting_Asset_Tool_Shears_Uncommon", "Crafting_Asset_Tool_Hammer_Common", ], "Needle": ["Crafting_Asset_Tool_Needle_Epic", "Crafting_Asset_Tool_Needle_Rare", "Crafting_Asset_Tool_Needle_Uncommon", "Crafting_Asset_Tool_Needle_Common", ], "Bellows": ["Crafting_Asset_Tool_Bellows_Epic", "Crafting_Asset_Tool_Bellows_Rare", "Crafting_Asset_Tool_Bellows_Uncommon", "Crafting_Asset_Tool_Bellows_Common"], "Bezelpusher": ["Crafting_Asset_Tool_Bezelpusher_Epic", "Crafting_Asset_Tool_Bezelpusher_Rare", "Crafting_Asset_Tool_Bezelpusher_Uncommon", "Crafting_Asset_Tool_Bezelpusher_Common"], "Mortar": ["Asset_Tool_Mortar_Epic", "Asset_Tool_Mortar_Rare", "Asset_Tool_Mortar_Uncommon", "Asset_Tool_Mortar_Common"], "Anvil": ["Crafting_Asset_Tool_Anvil_Epic", "Crafting_Asset_Tool_Anvil_Rare", "Crafting_Asset_Tool_Anvil_Uncommon", "Crafting_Asset_Tool_Anvil_Common", ], "Grindstone": ["Crafting_Asset_Tool_Grindstone_Epic", "Crafting_Asset_Tool_Grindstone_Rare", "Crafting_Asset_Tool_Grindstone_Uncommon", "Crafting_Asset_Tool_Grindstone_Common", ], "Philosophersstone": ["Asset_Tool_Philosophersstone_Epic", "Asset_Tool_Philosophersstone_Rare", "Asset_Tool_Philosophersstone_Uncommon", "Asset_Tool_Philosophersstone_Common"], "Loupe": ["Crafting_Asset_Tool_Loupe_Epic", "Crafting_Asset_Tool_Loupe_Rare", "Crafting_Asset_Tool_Loupe_Uncommon", "Crafting_Asset_Tool_Loupe_Common", ], "Graver": ["Crafting_Asset_Tool_Graver_Epic", "Crafting_Asset_Tool_Graver_Rare", "Crafting_Asset_Tool_Graver_Uncommon", "Crafting_Asset_Tool_Graver_Common", ], "Crucible": ["Asset_Tool_Crucible_Epic", "Asset_Tool_Crucible_Rare", "Asset_Tool_Crucible_Uncommon", "Asset_Tool_Crucible_Common", ], "Tongs": ["Crafting_Asset_Tool_Tongs_Epic", "Crafting_Asset_Tool_Tongs_Rare", "Crafting_Asset_Tool_Tongs_Uncommon", "Crafting_Asset_Tool_Tongs_Common", ], /* "Crafting_Asset_Tool_Leatherworking_T1_Epic", "Crafting_Asset_Tool_Gauntlets_Common" "Crafting_Asset_Tool_Leadership_T3_Common","Crafting_Asset_Tool_Leadership_T2_Common" */ } } function audioFile() { return "<audio id='soundFX'><source src='"+ "data:audio/mpeg;base64,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"+ "01Mfm6AAFzkmY3NNAAOEOtD/PMAKO+O5beeMAUCgWhYdFYcZcCwMMuBYEDhmAchBECAwmcR+BYYA9kAwzAUdoENAXRgLBDQ2AkMC6sV0NVixAZsWNNjpbBqYEbnzNAEg4qQzAcuPj9N94eoKmICCdB1CUP/8qCtB"+ "4IuKUJUXH//+SxAyJlkg7kHNi5///5uo0cwQEBR3/+kaFw+TLoHf///+4MWW3MmugDPT8BgMBgAALyMlWjJqQrXDcRW5NzIgkKBxsAj0USIuMCGhA0BeUdrGQMQ0EYKZfEbLRyCCDBmmP7aAWY7xgy8Q34niPD+b"+ "EoMsmf/mgEGHP5w0T/6V3uCavLqGIFLt///2FDScnS8H0BmOFFGkzSp1WoaodNIhOeiVZ6olXmaqv3mZrfMzMzrzMzn/mZntVTOf1VVONVVVVjVVVv9VVV5NI1W95NIkTgUFBTYoKbkCgvAoJdkFBRoUFBT4QU8F"+ "t/goN/QUF+KKEt1oABl9wAHwrkONJVLkgoOUl0M5TRNFQ+1l/9mYozMeqs31VVWOqqqq9UBEmwgUF8KCf8KCjYQUN/IbUxBTUUzLjk4LjJVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV"+ "VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVX/+xBkKo/wAABpAAAACAAADSAAAAEAAAGkAAAAIAAANIAAAARVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV"+ "VVVVVVVVVVVVVVVVVVVVVVVVUFQRVRBR0VY0AcAAFAAAAACAAAAAAAAoAAAAAAAAAAADgAAAAAAAABBcnRpc3QAU291bmRCaWJsZS5jb20FAAAAAAAAAEdlbnJlAE90aGVyQVBFVEFHRVjQBwAAUAAAAAIAAAAAA"+ "ACAAAAAAAAAAABUQUcAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBbGxTb3VuZHNBcm91bmQuY29tAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"+ "AAAAAAAAAAAAAAAAAAAAAAADA=='></source></audio>"; }