From e970fef991b66044013416ce08d0fd8e51a6abd1 Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Wed, 14 Dec 2022 19:06:49 +0100 Subject: [PATCH] Fetcher + VisualSelector - xPath filter with attribute filter was breaking the element finder --- .../res/xpath_element_scraper.js | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/changedetectionio/res/xpath_element_scraper.js b/changedetectionio/res/xpath_element_scraper.js index db76652b..0bbc035d 100644 --- a/changedetectionio/res/xpath_element_scraper.js +++ b/changedetectionio/res/xpath_element_scraper.js @@ -174,10 +174,23 @@ if (include_filters.length) { } if (q) { - bbox = q.getBoundingClientRect(); - console.log("xpath_element_scraper: Got filter element, scroll from top was "+scroll_y) - } else { - console.log("xpath_element_scraper: filter element "+f+" was not found"); + // #1231 - IN the case XPath attribute filter is applied, we will have to traverse up and find the element. + if (q.hasOwnProperty('getBoundingClientRect')) { + bbox = q.getBoundingClientRect(); + console.log("xpath_element_scraper: Got filter element, scroll from top was " + scroll_y) + } else { + try { + // Try and see we can find its ownerElement + bbox = q.ownerElement.getBoundingClientRect(); + console.log("xpath_element_scraper: Got filter by ownerElement element, scroll from top was " + scroll_y) + } catch (e) { + console.log("xpath_element_scraper: error looking up ownerElement") + } + } + } + + if(!q) { + console.log("xpath_element_scraper: filter element " + f + " was not found"); } if (bbox && bbox['width'] > 0 && bbox['height'] > 0) {