More JS tweaks

restock-visualselector-refactor
dgtlmoon 11 months ago
parent 62b55df7e5
commit b045a72460

@ -126,10 +126,7 @@ function isItemInStock() {
} }
} }
// Create an array to hold the visible elements
const elementsToScan = []; const elementsToScan = [];
// Call collectVisibleElements with the starting parent element
collectVisibleElements(document.body, elementsToScan); collectVisibleElements(document.body, elementsToScan);
var elementText = ""; var elementText = "";
@ -143,7 +140,6 @@ function isItemInStock() {
continue continue
} }
elementText = ""; elementText = "";
if (element.tagName.toLowerCase() === "input") { if (element.tagName.toLowerCase() === "input") {
elementText = element.value.toLowerCase(); elementText = element.value.toLowerCase();
@ -154,6 +150,7 @@ function isItemInStock() {
if (elementText.length) { if (elementText.length) {
// try which ones could mean its in stock // try which ones could mean its in stock
if (negateOutOfStockRegex.test(elementText)) { if (negateOutOfStockRegex.test(elementText)) {
console.log(`Negating/overriding 'Out of Stock' back to "Possibly in stock" found "${elementText}"`)
return 'Possibly in stock'; return 'Possibly in stock';
} }
} }
@ -167,25 +164,25 @@ function isItemInStock() {
if (element.getBoundingClientRect().top + window.scrollY >= vh || element.getBoundingClientRect().top + window.scrollY <= 100) { if (element.getBoundingClientRect().top + window.scrollY >= vh || element.getBoundingClientRect().top + window.scrollY <= 100) {
continue continue
} }
if (element.offsetWidth > 0 || element.offsetHeight > 0 || element.getClientRects().length > 0) { elementText = "";
elementText = ""; if (element.tagName.toLowerCase() === "input") {
if (element.tagName.toLowerCase() === "input") { elementText = element.value.toLowerCase();
elementText = element.value.toLowerCase(); } else {
} else { elementText = getElementBaseText(element);
elementText = getElementBaseText(element); }
}
if (elementText.length) { if (elementText.length) {
// and these mean its out of stock // and these mean its out of stock
for (const outOfStockText of outOfStockTexts) { for (const outOfStockText of outOfStockTexts) {
if (elementText.includes(outOfStockText)) { if (elementText.includes(outOfStockText)) {
return outOfStockText; // item is out of stock console.log(`Selected 'Out of Stock' - found text "${outOfStockText}"`)
} return outOfStockText; // item is out of stock
} }
} }
} }
} }
console.log(`Returning 'Possibly in stock' - cant' find any useful matching text`)
return 'Possibly in stock'; // possibly in stock, cant decide otherwise. return 'Possibly in stock'; // possibly in stock, cant decide otherwise.
} }

@ -139,7 +139,7 @@ visibleElementsArray.forEach(function (element) {
bbox = element.getBoundingClientRect(); bbox = element.getBoundingClientRect();
// Skip really small ones, and where width or height ==0 // Skip really small ones, and where width or height ==0
if (bbox['width'] * bbox['height'] < 100) { if (bbox['width'] * bbox['height'] < 10) {
return return
} }

Loading…
Cancel
Save