mirror of
https://github.com/internetarchive/brozzler.git
synced 2025-02-24 00:29:53 -05:00
Merge pull request #166 from CorentinB/facebook-ads-lib
Add support for Facebook ads library and fix closing
This commit is contained in:
commit
7273c7c3a2
@ -17,6 +17,15 @@
|
||||
#
|
||||
|
||||
# first matched behavior is used, so order matters here
|
||||
-
|
||||
url_regex: '^https?://(?:www\.)?facebook\.com/ads/library/.*$'
|
||||
behavior_js_template: umbraBehavior.js.j2
|
||||
request_idle_timeout_sec: 30
|
||||
default_parameters:
|
||||
interval: 500
|
||||
actions:
|
||||
- selector: 'a[data-testid="snapshot_footer_link"]'
|
||||
closeSelector: 'div._7lq1 > button'
|
||||
-
|
||||
url_regex: '^https?://(?:www\.)?facebook\.com/.*$'
|
||||
behavior_js_template: facebook.js
|
||||
|
@ -43,6 +43,7 @@ class UmbraBehavior {
|
||||
|
||||
var documents = [];
|
||||
documents[0] = document;
|
||||
|
||||
var iframes = document.querySelectorAll("iframe");
|
||||
var iframesLength = iframes.length;
|
||||
for (var i = 0; i < iframesLength; i++) {
|
||||
@ -54,25 +55,31 @@ class UmbraBehavior {
|
||||
// console.log("exception looking at iframe" + iframes[i] + ": " + e);
|
||||
}
|
||||
}
|
||||
|
||||
var documentsLength = documents.length;
|
||||
for (var j = 0; j < documentsLength; j++) {
|
||||
if (closeSelector) {
|
||||
var closeTargets = documents[j].querySelectorAll(closeSelector);
|
||||
if ((closeTargets.length > 0) &&
|
||||
(this.alreadyDone.indexOf(closeTargets[0]) === -1) &&
|
||||
(this.isVisible(closeTargets[0]))) {
|
||||
doTarget(closeTargets[0], 'click');
|
||||
for (var i = 0; i < closeTargets.length; i++) {
|
||||
if (this.isVisible(closeTargets[i])) {
|
||||
closeTargets[i].click();
|
||||
didSomething = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (firstMatchOnly) {
|
||||
var doTargets = [ documents[j].querySelector(selector) ];
|
||||
} else {
|
||||
var doTargets = documents[j].querySelectorAll(selector);
|
||||
}
|
||||
|
||||
var doTargetsLength = doTargets.length;
|
||||
if (!(doTargetsLength > 0)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
for ( var i = 0; i < doTargetsLength; i++) {
|
||||
if (!repeatSameElement && this.alreadyDone.indexOf(doTargets[i]) > -1) {
|
||||
continue;
|
||||
|
Loading…
x
Reference in New Issue
Block a user