180 lines
6.6 KiB
JavaScript
180 lines
6.6 KiB
JavaScript
let equipment_keys = ['weapon', 'helmet', 'chestplate', 'leggings', 'boots', 'ring1', 'ring2', 'bracelet', 'necklace'];
|
|
let weapon_keys = ['dagger', 'wand', 'bow', 'relik', 'spear']
|
|
let skp_keys = ['str', 'dex', 'int', 'def', 'agi'];
|
|
|
|
document.addEventListener('DOMContentLoaded', function() {
|
|
|
|
for (const i in equipment_keys) {
|
|
document.querySelector("#"+equipment_keys[i]+"-choice").setAttribute("oninput", "calcBuildSchedule()");
|
|
document.querySelector("#"+equipment_keys[i]+"-powder").setAttribute("oninput", "calcBuildSchedule()");
|
|
}
|
|
document.querySelector("#level-choice").setAttribute("oninput", "calcBuildSchedule()")
|
|
|
|
let skp_fields = document.getElementsByClassName("skp-update");
|
|
|
|
for (i = 0; i < skp_fields.length; i++) {
|
|
skp_fields[i].setAttribute("oninput", "updateStatSchedule()");
|
|
}
|
|
});
|
|
|
|
// phanta scheduler
|
|
let calcBuildTask = null;
|
|
let updateStatTask = null;
|
|
let doSearchTask = null;
|
|
|
|
function calcBuildSchedule(){
|
|
if (calcBuildTask !== null) {
|
|
clearTimeout(calcBuildTask);
|
|
}
|
|
calcBuildTask = setTimeout(function(){
|
|
calcBuildTask = null;
|
|
calculateBuild();
|
|
}, 1000);
|
|
}
|
|
|
|
function updateStatSchedule(){
|
|
if (updateStatTask !== null) {
|
|
clearTimeout(updateStatTask);
|
|
}
|
|
updateStatTask = setTimeout(function(){
|
|
updateStatTask = null;
|
|
updateStats();
|
|
}, 500);
|
|
}
|
|
|
|
function doSearchSchedule(){
|
|
if (doSearchTask !== null) {
|
|
clearTimeout(doSearchTask);
|
|
}
|
|
doSearchTask = setTimeout(function(){
|
|
doSearchTask = null;
|
|
doItemSearch();
|
|
}, 500);
|
|
}
|
|
|
|
// equipment field dynamic styling
|
|
|
|
function update_fields() {
|
|
for (const i in equipment_keys) {
|
|
|
|
// resets
|
|
document.querySelector("#"+equipment_keys[i]+"-choice").classList.remove("text-light", "is-invalid", 'Normal', 'Unique', 'Rare', 'Legendary', 'Fabled', 'Mythic', 'Set');
|
|
console.log(document.querySelector("#"+equipment_keys[i]+"-choice").value)
|
|
let item = player_build[equipment_keys[i]];
|
|
|
|
if ((item.get('name') == 'No '+ equipment_keys[i].charAt(0).toUpperCase() + equipment_keys[i].slice(1)) && (document.querySelector("#"+equipment_keys[i]+"-choice").value)) {
|
|
document.querySelector("#"+equipment_keys[i]+"-choice").classList.add("text-light", "is-invalid");
|
|
document.querySelector("#"+equipment_keys[i]+"-powder").disabled = true;
|
|
continue;
|
|
}
|
|
|
|
// set input text color
|
|
document.querySelector("#"+equipment_keys[i]+"-choice").classList.add(item.get('tier'));
|
|
|
|
// set powder slots
|
|
document.querySelector("#"+equipment_keys[i]+"-powder").setAttribute("placeholder", item.get('slots')+" slots");
|
|
|
|
if (item.get('slots') == 0) {
|
|
document.querySelector("#"+equipment_keys[i]+"-powder").disabled = true;
|
|
} else {
|
|
document.querySelector("#"+equipment_keys[i]+"-powder").disabled = false;
|
|
}
|
|
|
|
// set weapon image
|
|
if (item.get('category') == 'weapon') {
|
|
document.querySelector("#weapon-img").setAttribute('src', 'media/items/new/generic-'+item.get('type')+'.png');
|
|
}
|
|
}
|
|
}
|
|
|
|
// tabular stats
|
|
let tabs = ['all-stats', 'minimal-offensive-stats', 'minimal-defensive-stats'];
|
|
|
|
function show_tab(tab) {
|
|
for (const i in tabs) {
|
|
document.querySelector("#"+tabs[i]).style.display = "none";
|
|
}
|
|
document.querySelector("#"+tab).style.display = "";
|
|
}
|
|
|
|
// autocomplete initialize
|
|
function init_autocomplete() {
|
|
let dropdowns = new Map()
|
|
for (const i in equipment_keys) {
|
|
// build dropdown
|
|
console.log('init dropdown for '+ equipment_keys[i])
|
|
let item_arr = [];
|
|
if (equipment_keys[i] == 'weapon') {
|
|
for (const weaponType of weapon_keys) {
|
|
for (const weapon of itemLists.get(weaponType)) {
|
|
let item_obj = itemMap.get(weapon);
|
|
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
|
continue;
|
|
}
|
|
if (item_obj["name"] == 'No '+ equipment_keys[i].charAt(0).toUpperCase() + equipment_keys[i].slice(1)) {
|
|
continue;
|
|
}
|
|
item_arr.push(weapon);
|
|
}
|
|
}
|
|
} else {
|
|
for (const item of itemLists.get(equipment_keys[i].replace(/[0-9]/g, ''))) {
|
|
let item_obj = itemMap.get(item);
|
|
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
|
continue;
|
|
}
|
|
if (item_obj["name"] == 'No '+ equipment_keys[i].charAt(0).toUpperCase() + equipment_keys[i].slice(1)) {
|
|
continue;
|
|
}
|
|
item_arr.push(item)
|
|
}
|
|
}
|
|
|
|
// create dropdown
|
|
dropdowns.set(equipment_keys[i], new autoComplete({
|
|
data: {
|
|
src: item_arr
|
|
},
|
|
selector: "#"+ equipment_keys[i] +"-choice",
|
|
wrapper: false,
|
|
resultsList: {
|
|
tabSelect: true,
|
|
noResults: true,
|
|
class: "search-box dark-7 rounded-bottom px-2 fw-bold dark-shadow-sm",
|
|
element: (list, data) => {
|
|
// dynamic result loc
|
|
let position = document.getElementById(equipment_keys[i]+'-dropdown').getBoundingClientRect();
|
|
list.style.top = position.bottom + window.scrollY +"px";
|
|
list.style.left = position.x+"px";
|
|
list.style.width = position.width+"px";
|
|
|
|
if (!data.results.length) {
|
|
message = document.createElement('li');
|
|
message.classList.add('scaled-font');
|
|
message.textContent = "Add: "+ data.query;
|
|
message.value = data.query;
|
|
list.prepend(message);
|
|
}
|
|
},
|
|
},
|
|
resultItem: {
|
|
class: "scaled-font search-item",
|
|
selected: "dark-5",
|
|
element: (item, data) => {
|
|
item.classList.add(itemMap.get(data.value).tier);
|
|
},
|
|
},
|
|
events: {
|
|
input: {
|
|
selection: (event) => {
|
|
if (event.detail.selection.value) {
|
|
event.target.value = event.detail.selection.value;
|
|
}
|
|
update_fields(equipment_keys[i]);
|
|
calcBuildSchedule();
|
|
},
|
|
},
|
|
}
|
|
}));
|
|
}
|
|
}
|