// ==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>";
}