refactor: implement phanta schedule handler

This commit is contained in:
reschan 2021-10-18 16:41:45 +07:00
parent fda8590c9d
commit 567744ab0b

153
sq2.js
View file

@ -2,8 +2,6 @@ let equipment_keys = ['weapon', 'helmet', 'chestplate', 'leggings', 'boots', 'ri
$(document).ready(function(){ $(document).ready(function(){
// inits // inits
// $("#column2").height($("#column1").height());
// $("#column3").height($("#column1").height());
$("#overall-window").toggle(); $("#overall-window").toggle();
$("#search-container").toggle(); $("#search-container").toggle();
@ -36,6 +34,7 @@ $(document).ready(function(){
handle: '#boost-container-header', handle: '#boost-container-header',
}); });
// window priority
$("#overall-window").mousedown(function() { $("#overall-window").mousedown(function() {
$(".window-container").css("z-index", 10); $(".window-container").css("z-index", 10);
$(this).css("z-index", 11); $(this).css("z-index", 11);
@ -52,98 +51,83 @@ $(document).ready(function(){
}); });
// update builds // update builds
jQuery(document).on("keypress", '.item-name', function(event){ jQuery(document).on("input", '.skp-input', function(event){
if (event.keyCode == 13) { updateStatSchedule();
calculateBuild();
}
}); });
jQuery(document).on("keypress", '.powder-input', function(event){ jQuery(document).on("input", '.search-field', function(event){
if (event.keyCode == 13) { doSearchSchedule();
calculateBuild();
}
});
jQuery(document).on("keypress", '.skp-input', function(event){
if (event.keyCode == 13) {
updateStats();
}
});
jQuery(document).on("keypress", '.search-field', function(event){
if (event.keyCode == 13) {
doItemSearch();
}
}); });
// set listeners/checks // set listeners/checks
$("#weapon-choice").on('input', function(){ $("#weapon-choice").on('input', function(){
setTimeout(function() {
set_input_style('weapon'); set_input_style('weapon');
check_item($("#weapon-choice").val()); calcBuildSchedule();
update_powder_count('weapon'); update_powder_count('weapon');
}, 500); });
$("#weapon-powder").on('input', function(){
calcBuildSchedule();
}); });
$("#helmet-choice").on('input', function(){ $("#helmet-choice").on('input', function(){
setTimeout(function() {
set_input_style('helmet'); set_input_style('helmet');
check_item($("#helmet-choice").val()); calcBuildSchedule();
update_powder_count('helmet', '|example: t6t6'); update_powder_count('helmet', '|example: t6t6');
}, 500); });
$("#helmet-powder").on('input', function(){
calcBuildSchedule();
}); });
$("#chestplate-choice").on('input', function(){ $("#chestplate-choice").on('input', function(){
setTimeout(function() {
set_input_style('chestplate'); set_input_style('chestplate');
check_item($("#chestplate-choice").val()); calcBuildSchedule();
update_powder_count('chestplate'); update_powder_count('chestplate');
}, 500); });
$("#chestplate-powder").on('input', function(){
calcBuildSchedule();
}); });
$("#leggings-choice").on('input', function(){ $("#leggings-choice").on('input', function(){
setTimeout(function() {
set_input_style('leggings'); set_input_style('leggings');
check_item($("#leggings-choice").val()); calcBuildSchedule();
update_powder_count('leggings'); update_powder_count('leggings');
}, 500); });
$("#leggings-powder").on('input', function(){
calcBuildSchedule();
}); });
$("#boots-choice").on('input', function(){ $("#boots-choice").on('input', function(){
setTimeout(function() {
set_input_style('boots'); set_input_style('boots');
check_item($("#boots-choice").val()); calcBuildSchedule();
update_powder_count('boots'); update_powder_count('boots');
}, 500); });
$("#boots-powder").on('input', function(){
calcBuildSchedule();
}); });
$("#ring1-choice").on('input', function(){ $("#ring1-choice").on('input', function(){
setTimeout(function() {
set_input_style('ring1'); set_input_style('ring1');
check_item($("#ring1-choice").val()); calcBuildSchedule();
}, 500);
}); });
$("#ring2-choice").on('input', function(){ $("#ring2-choice").on('input', function(){
setTimeout(function() {
set_input_style('ring2'); set_input_style('ring2');
check_item($("#ring2-choice").val()); calcBuildSchedule();
}, 500);
}); });
$("#bracelet-choice").on('input', function(){ $("#bracelet-choice").on('input', function(){
setTimeout(function() {
set_input_style('bracelet'); set_input_style('bracelet');
check_item($("#bracelet-choice").val()); calcBuildSchedule();
}, 500);
}); });
$("#necklace-choice").on('input', function(){ $("#necklace-choice").on('input', function(){
setTimeout(function() {
set_input_style('necklace'); set_input_style('necklace');
check_item($("#necklace-choice").val()); calcBuildSchedule();
}, 500);
}); });
// control vars // control vars
@ -300,18 +284,6 @@ function set_input_style(type) {
} }
} }
function check_item(name) {
if (itemMap.has(name)) {
calculateBuild()
}
}
function check_powder(powders) {
if (powders.length % 2 == 0) {
}
}
function init_tooltip_loc(equipment){ function init_tooltip_loc(equipment){
let ImgLoc = document.getElementById(equipment+'-img-loc').getBoundingClientRect(); let ImgLoc = document.getElementById(equipment+'-img-loc').getBoundingClientRect();
let tooltipRect = document.getElementById(equipment+"-tooltip").getBoundingClientRect(); let tooltipRect = document.getElementById(equipment+"-tooltip").getBoundingClientRect();
@ -321,30 +293,6 @@ function init_tooltip_loc(equipment){
$("#"+equipment+"-tooltip").css('left', ImgLoc.right); $("#"+equipment+"-tooltip").css('left', ImgLoc.right);
} }
/*
document.getElementById(armorType+"-choice").addEventListener("change", (event) => {
let item_name = event.target.value;
let nSlots = undefined;
if (itemMap.has(item_name)) {
let item = itemMap.get(item_name);
nSlots = item["slots"];
//console.log(item);
}
else {
let crafted_custom_item = getCraftFromHash(item_name) !== undefined ? getCraftFromHash(item_name) : (getCustomFromHash(item_name) !== undefined ? getCustomFromHash(item_name) : undefined);
if (crafted_custom_item !== undefined) {
nSlots = crafted_custom_item.statMap.get("slots");
}
}
if (nSlots !== undefined) {
document.getElementById(armorType+"-slots").textContent = nSlots + " slots";
}
else {
document.getElementById(armorType+"-slots").textContent = "X slots";
}
});*/
function update_powder_count(type, alt="") { function update_powder_count(type, alt="") {
let item = itemMap.get($("#"+type+"-choice").val()); let item = itemMap.get($("#"+type+"-choice").val());
if (item) { if (item) {
@ -362,3 +310,38 @@ function init_equipUI() {
update_powder_count('leggings'); update_powder_count('leggings');
update_powder_count('boots'); update_powder_count('boots');
} }
// phanta method of handling input <3
let calcBuildTask = null;
let updateStatTask = null;
let doSearchTask = null;
function calcBuildSchedule(){
if (calcBuildTask !== null) {
clearTimeout(calcBuildTask);
}
calcBuildTask = setTimeout(function(){
calcBuildTask = null;
calculateBuild();
}, 500);
}
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);
}