In PHOTO PAGE: Auto click on the View Adult Content (author Brock Adams , fork decembre)
// ==UserScript== // @name Flickr - AUTO View ADULT Content v.1 - 2017 // @description In PHOTO PAGE: Auto click on the View Adult Content (author Brock Adams , fork decembre) // @version v.1 // @autor Decembre // @namespace https://greasyfork.org/users/8 // @include http*://www.flickr.com/photos/* // @require http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js // @grant GM_addStyle // ==/UserScript== // FROM a script of Brock Adams (Thanks to him!) // in stackoverflow : // http://stackoverflow.com/questions/12252701/how-do-i-click-on-this-button-with-greasemonkey?lq=1 // with : // https://gist.github.com/raw/2625891/waitForKeyElements.js /*- The @grant directive is needed to work around a major design change introduced in GM 1.0. It restores the sandbox. */ /*--- waitForKeyElements(): FIND IT HERE : https://gist.github.com/raw/2625891/waitForKeyElements.js A utility function, for Greasemonkey scripts, that detects and handles AJAXed content. Usage example: waitForKeyElements ( "div.comments" , commentCallbackFunction ); //--- Page-specific function to do what we want when the node is found. function commentCallbackFunction (jNode) { jNode.text ("This comment changed by waitForKeyElements()."); } IMPORTANT: This function requires your script to have loaded jQuery. */ function waitForKeyElements ( selectorTxt, /* Required: The jQuery selector string that specifies the desired element(s). */ actionFunction, /* Required: The code to run when elements are found. It is passed a jNode to the matched element. */ bWaitOnce, /* Optional: If false, will continue to scan for new elements even after the first match is found. */ iframeSelector /* Optional: If set, identifies the iframe to search. */ ) { var targetNodes, btargetsFound; if (typeof iframeSelector == "undefined") targetNodes = $(selectorTxt); else targetNodes = $(iframeSelector).contents () .find (selectorTxt); if (targetNodes && targetNodes.length > 0) { btargetsFound = true; /*--- Found target node(s). Go through each and act if they are new. */ targetNodes.each ( function () { var jThis = $(this); var alreadyFound = jThis.data ('alreadyFound') || false; if (!alreadyFound) { //--- Call the payload function. var cancelFound = actionFunction (jThis); if (cancelFound) btargetsFound = false; else jThis.data ('alreadyFound', true); } } ); } else { btargetsFound = false; } //--- Get the timer-control variable for this selector. var controlObj = waitForKeyElements.controlObj || {}; var controlKey = selectorTxt.replace (/[^\w]/g, "_"); var timeControl = controlObj [controlKey]; //--- Now set or clear the timer as appropriate. if (btargetsFound && bWaitOnce && timeControl) { //--- The only condition where we need to clear the timer. clearInterval (timeControl); delete controlObj [controlKey] } else { //--- Set a timer, if needed. if ( ! timeControl) { timeControl = setInterval ( function () { waitForKeyElements ( selectorTxt, actionFunction, bWaitOnce, iframeSelector ); }, 300 ); controlObj [controlKey] = timeControl; } } waitForKeyElements.controlObj = controlObj; } //--- Note that contains() is CASE-SENSITIVE. //waitForKeyElements ("a.simplebutton:contains('follow')", clickOnFollowButton); // TEST 1 (function(){ function clickOnAdultContent(node){ console.log ("Found View Adult Content. Clicking it!"); //node.click(); var clickEvent = document.createEvent ('MouseEvents'); clickEvent.initEvent ('click', true, true); node[0].dispatchEvent (clickEvent); return true; } console.log ("Waiting for View Adult Content button"); waitForKeyElements(".photo-well-scrappy-view .height-controller .photo-well-media-scrappy-view > .restricted-interstitial > .restricted-interstitial-message p + p button.ui-button", clickOnAdultContent); })(); /* // TEST 2 (not working) waitForKeyElements (".photo-well-scrappy-view .height-controller .photo-well-media-scrappy-view > .restricted-interstitial > .restricted-interstitial-message p + p button.ui-button", clickOnAdultContent); function clickOnAdultContent (jNode) { var clickEvent = document.createEvent ('MouseEvents'); clickEvent.initEvent ('click', true, true); jNode[0].dispatchEvent (clickEvent); } */