fix: update_fields supports CI/CR
This commit is contained in:
parent
cbfd8d0a4e
commit
2413a2654f
2 changed files with 45 additions and 35 deletions
73
sq2bs.js
73
sq2bs.js
|
@ -53,41 +53,35 @@ function doSearchSchedule(){
|
||||||
}
|
}
|
||||||
|
|
||||||
// equipment field dynamic styling
|
// equipment field dynamic styling
|
||||||
function update_fields(type, alt="") {
|
|
||||||
let item = itemMap.get(document.querySelector("#"+type+"-choice").value);
|
|
||||||
if (item && ((item.type == type.replace(/[0-9]/g, '')) || (item.category == type))) {
|
|
||||||
// powder styling
|
|
||||||
document.querySelector("#"+type+"-powder").setAttribute("placeholder", item["slots"]+" slots"+alt);
|
|
||||||
|
|
||||||
if (item['slots'] == 0) {
|
function update_fields() {
|
||||||
document.querySelector("#"+type+"-powder").disabled = true;
|
|
||||||
} else {
|
|
||||||
document.querySelector("#"+type+"-powder").disabled = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// input box styling
|
|
||||||
document.querySelector("#"+type+"-choice").classList.remove("text-light", "is-invalid", 'Normal', 'Unique', 'Rare', 'Legendary', 'Fabled', 'Mythic', 'Set');
|
|
||||||
document.querySelector("#"+type+"-choice").classList.add(item.tier);
|
|
||||||
|
|
||||||
if (type == 'weapon') {
|
|
||||||
document.querySelector("#"+type+"-img").setAttribute('src', 'media/items/new/generic-'+item.type+'.png');
|
|
||||||
}
|
|
||||||
} else if (document.querySelector("#"+type+"-choice").value == '') {
|
|
||||||
document.querySelector("#"+type+"-choice").classList.remove("is-invalid", 'Normal', 'Unique', 'Rare', 'Legendary', 'Fabled', 'Mythic', 'Set');
|
|
||||||
document.querySelector("#"+type+"-powder").setAttribute("placeholder", '0 slots');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
document.querySelector("#"+type+"-choice").classList.remove('Normal', 'Unique', 'Rare', 'Legendary', 'Fabled', 'Mythic', 'Set');
|
|
||||||
document.querySelector("#"+type+"-choice").classList.add("text-light", "is-invalid");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function init_field_styles() {
|
|
||||||
for (const i in equipment_keys) {
|
for (const i in equipment_keys) {
|
||||||
update_fields(equipment_keys[i]);
|
|
||||||
|
// resets
|
||||||
|
document.querySelector("#"+equipment_keys[i]+"-choice").classList.remove("text-light", "is-invalid", 'Normal', 'Unique', 'Rare', 'Legendary', 'Fabled', 'Mythic', 'Set');
|
||||||
|
|
||||||
|
let item = player_build[equipment_keys[i]];
|
||||||
|
|
||||||
|
// 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');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function get_item_color(item) {
|
function get_item_color(item) {
|
||||||
item = itemMap.get(item);
|
item = itemMap.get(item);
|
||||||
if (item) {return item.tier} else {return ''}
|
if (item) {return item.tier} else {return ''}
|
||||||
|
@ -108,6 +102,7 @@ function init_autocomplete() {
|
||||||
let dropdowns = new Map()
|
let dropdowns = new Map()
|
||||||
for (const i in equipment_keys) {
|
for (const i in equipment_keys) {
|
||||||
// build dropdown
|
// build dropdown
|
||||||
|
console.log('init dropdown for '+ equipment_keys[i])
|
||||||
let item_arr = [];
|
let item_arr = [];
|
||||||
if (equipment_keys[i] == 'weapon') {
|
if (equipment_keys[i] == 'weapon') {
|
||||||
for (const weaponType of weapon_keys) {
|
for (const weaponType of weapon_keys) {
|
||||||
|
@ -116,6 +111,9 @@ function init_autocomplete() {
|
||||||
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (item_obj["name"] == 'No '+ equipment_keys[i].charAt(0).toUpperCase() + equipment_keys[i].slice(1)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
item_arr.push(weapon);
|
item_arr.push(weapon);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -125,6 +123,9 @@ function init_autocomplete() {
|
||||||
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
if (item_obj["restrict"] && item_obj["restrict"] === "DEPRECATED") {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (item_obj["name"] == 'No '+ equipment_keys[i].charAt(0).toUpperCase() + equipment_keys[i].slice(1)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
item_arr.push(item)
|
item_arr.push(item)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -138,6 +139,7 @@ function init_autocomplete() {
|
||||||
wrapper: false,
|
wrapper: false,
|
||||||
resultsList: {
|
resultsList: {
|
||||||
tabSelect: true,
|
tabSelect: true,
|
||||||
|
noResults: true,
|
||||||
class: "search-box dark-7 rounded-bottom px-2 fw-bold dark-shadow-sm",
|
class: "search-box dark-7 rounded-bottom px-2 fw-bold dark-shadow-sm",
|
||||||
element: (list, data) => {
|
element: (list, data) => {
|
||||||
// dynamic result loc
|
// dynamic result loc
|
||||||
|
@ -145,6 +147,13 @@ function init_autocomplete() {
|
||||||
list.style.top = position.bottom + window.scrollY +"px";
|
list.style.top = position.bottom + window.scrollY +"px";
|
||||||
list.style.left = position.x+"px";
|
list.style.left = position.x+"px";
|
||||||
list.style.width = position.width+"px";
|
list.style.width = position.width+"px";
|
||||||
|
|
||||||
|
if (!data.results.length) {
|
||||||
|
message = document.createElement('li');
|
||||||
|
message.textContent = "Add: "+ data.query;
|
||||||
|
message.value = data.query;
|
||||||
|
list.prepend(message);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
resultItem: {
|
resultItem: {
|
||||||
|
@ -157,7 +166,9 @@ function init_autocomplete() {
|
||||||
events: {
|
events: {
|
||||||
input: {
|
input: {
|
||||||
selection: (event) => {
|
selection: (event) => {
|
||||||
event.target.value = event.detail.selection.value;
|
if (event.detail.selection.value) {
|
||||||
|
event.target.value = event.detail.selection.value;
|
||||||
|
}
|
||||||
update_fields(equipment_keys[i]);
|
update_fields(equipment_keys[i]);
|
||||||
calcBuildSchedule();
|
calcBuildSchedule();
|
||||||
},
|
},
|
||||||
|
|
|
@ -71,7 +71,6 @@ let powderInputs = [
|
||||||
|
|
||||||
function init() {
|
function init() {
|
||||||
console.log("builder.js init");
|
console.log("builder.js init");
|
||||||
init_field_styles();
|
|
||||||
init_autocomplete();
|
init_autocomplete();
|
||||||
decodeBuild(url_tag);
|
decodeBuild(url_tag);
|
||||||
}
|
}
|
||||||
|
@ -741,11 +740,11 @@ function calculateBuildStats() {
|
||||||
for (let i in player_build.items) {
|
for (let i in player_build.items) {
|
||||||
// displaysq2ExpandedItem(player_build.items[i], buildFields[i], true);
|
// displaysq2ExpandedItem(player_build.items[i], buildFields[i], true);
|
||||||
}
|
}
|
||||||
console.log(player_build)
|
|
||||||
console.log("build")
|
update_fields()
|
||||||
|
|
||||||
displaysq2ArmorStats(player_build);
|
displaysq2ArmorStats(player_build);
|
||||||
displaysq2BuildStats("all-stats", player_build, build_all_display_commands);
|
displaysq2BuildStats("all-stats", player_build, build_all_display_commands);
|
||||||
// displaysq2BuildStats("minimal-stats", player_build, build_basic_display_commands);
|
|
||||||
displaysq2BuildStats("minimal-offensive-stats",player_build, build_offensive_display_commands);
|
displaysq2BuildStats("minimal-offensive-stats",player_build, build_offensive_display_commands);
|
||||||
displaySetBonuses("set-info",player_build);
|
displaySetBonuses("set-info",player_build);
|
||||||
displayNextCosts("int-info",player_build);
|
displayNextCosts("int-info",player_build);
|
||||||
|
|
Loading…
Reference in a new issue