NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript==
// @name Simple Video Audio Blocker
// @version 1.7.2
// @description Block loading of videos/audio (flash or html5) at the site being visited. Click to enable once, alt-c to enable for site permanently.
// @include *
// @license GPL-3.0
// @updateURL https://openuserjs.org/meta/slow!/Simple_Video_Audio_Blocker.meta.js
// @run-at document-start
// @require https://code.jquery.com/jquery-3.2.1.js
// @require https://code.jquery.com/ui/1.12.1/jquery-ui.js
// @require https://raw.githubusercontent.com/SloaneFox/code/master/gm4-polyfill-1.0.1.js
// @require https://raw.githubusercontent.com/SloaneFox/code/master/sfs-utils-0.1.4.js
// @grant GM_getValue
// @grant GM_setValue
// @grant GM.getValue
// @grant GM.setValue
// @grant GM_registerMenuCommand
// ==/UserScript==
try{
console.log("Start of svab script, document.readyState:",document.readyState,"vids?:",document.getElementsByTagName("video").length);
var allow_site, pagekey, menu, orig_vol=0.33;
if (!environInit(main.bind(this))) document.addEventListener("DOMContentLoaded",main);
async function main(e) {try{
await init_globs();
if(allow_site) { console.info("Site has previously been given permission to run videos."); setupUI("allowed"); return; }
var vids=$("video"); // See mdn obj HTMLMediaElement.
vids.each(pauseVideo);
log("Handle vids",document.readyState,"#vids",vids.length);
if(vids.length) {
setupStyle();
setupUI("vids");
let doc=$(document);
doc.keydown(function(e){
if(e.which==27) {
$(".svab-overlay").click();
doc.off("keydown");
}
});
}
vids.each(blockVids);
} catch(e){logError("Error in main()",window.parent==window);} };
function blockVids(i,vid) {
var jvid=$(vid);
//log("Vid readyState:",vid.readyState,"Vid i=",i,objInfo(jvid),", prev:",objInfo(jvid.prev()),", next",objInfo(jvid.next()),"src",jvid.attr("src"));
jvid.on("playing volumechange",function(e) {try{
this.pause();
var vol=this.volume;
log("Playing/vol events",vol);
if(vol!=0) orig_vol=vol;;
pauseVideo(0,this);
} catch(e){logError("playing event handler",e);} });
overlayVid(jvid);
};
function pauseVideo(i,v) {
//$(v).on("playing",e=>v.pause());
v.volume=0;
v.autoplay=false;
v.defaultMuted=true;
var timeranges=v.seekable, nRanges=timeranges.length;
if(v.readyState<3) {return;} // needs 3 to be playable, that at at min 2 frames.
v.pause();
v.currentTime=v.duration-1;
log("pauseVideo(). Got timeranges",timeranges,"len",nRanges, "readystate:",v.readyState,"Video duration/seekend",v.duration,"/",v.seekable.end(nRanges-1)); // duration and end same, a float in seconds
}
function overlayVid(jv,v=jv[0]) {
jv.addClass("svab-target");
//log("is parent visible:",jv.parent().is(":visible"));
jv.parent().addClass("svab-container");
jv.after("<div class=svab-overlay/>");
var overlay=$(".svab-overlay");
overlay.click({jv:jv,v:v},clear);
overlay.on("mouseover mouseout mouseenter mousemove",e=>false);
jv.parentsUntil("body").each((i,el)=>{
var jel=$(el);
var opacity=jel.css("opacity"), width=jel.width(),height=jel.height(), changed;
if(opacity!=1 ) { jel.css("opacity",1); changed=true;}
if(width==0||height==0) { jel.width("90%");jel.height("90%"); changed=true; }
if(changed) {
jel.attr("svab_change",opacity+"-"+width+"-"+height);
//log("changed",opacity,width,height,jel[0]);
}
});
}
function clear (e){try{
var jv=e.data.jv,v=e.data.v;
//log("Click on overlay. this is:", this," e ",e,"vol:",v.volume);
jv.off("playing volumechange");
v.currentTime=0;
v.muted=false;
v.volume=orig_vol;
setTimeout(x=>v.play(),1000); // why?
jv.removeClass("svab-target");
jv.parent().removeClass("svab-container");
$(this).remove();
jv.click();
} catch(e){logError("clearing block",e);}}
function setupStyle() {
var img="";
var svab_style=GM_addStyle(`
.svab-container { width: 100%;height: 100%; position: relative !important; z-index:2147483635 !important;}
.svab-target, .svab-overlay { width: 100%; height: 100%; position: absolute; top: 0; left: 0; z-index:2147483640; }
.svab-overlay { z-index: 2147483647 !important; }
`);
if(svab_style) svab_style.id="svab-style"; else log("Old addStyle",GM_addStyle.toString());
GM_addStyle(`
.svab-overlay {
background:url(`+img+`); border:6px double silver; box-sizing: border-box;
min-width:50px;min-height:50px;
background-repeat: no-repeat;background-position: center; cursor:pointer;
background-color: #381714; display: inline-block;
}
`);
// Outline of HTML:
// <div class="svab-container">
// <div class="svab-target">a</div>
// <div class="svab-overlay background=..."> </div>
// </div>
} //End setupStyle()
function setupUI() {
menu=GM.registerMenuCommand("Toggle video blocking for website [on]",function(){try{
allow_site^=true;
GM.setValue(pagekey,allow_site);
if(allow_site) $(".svab-overlay").click();
else $("video").each(blockVids);
setLabel();
} catch(e){logError("toggle vid",e);} });
setLabel();
// GM.registerMenuCommand("Adjust",async function(){
// if (!this.reply) this.reply=await GM.getValue("adjust_reply","");
// while(true) {
// var reply=prompt("Give cmd",this.reply||"");
// if(!reply) break;
// alert(eval(reply));
// this.reply=reply;
// GM.setValue("adjust_reply",reply);
// }
// });
}
function setLabel() {
if(menu && menu.tagName) {
var m=$(menu), label=m.attr("label");
label=label.replace(/\[.*/, allow_site? "[off]." : "[on].");
m.attr("label",label);
}
}
async function init_globs() {
pagekey=location.host;
allow_site=await GM.getValue(pagekey,false);
}
} catch(e){ console.log("SVAB script",e);}
// function fastEvent() {
// $("video").each((i,el)=>{
// el.defaultMuted=true;el.volume=0; el.autoplay=false; el.pause();
// el.addEventListener("playing",function(e){this.pause();});
// el.addEventListener("volumechange",function(e){
// if(this.volume==0) return;
// this.volume=0; this.pause();
// log(this,"=this========== Volume changed to:",v,this.volume); //usu. vol changes to 1.
// });
// });
// console.log("DOMContentLoaded event #vids:",$("video").length);
// }
function environInit(cback) { // returns false if GM environment is there, otherwise it calls main when ready and immediately returns true.
this.plat_chrome=false; this.plat_msedge=false; //chrome standalone, ie, not under tamper in chrome. // this.plat_msedge=/Edge[\d./]+$/i.test(navigator.userAgent);
if (/Chrome/.test(navigator.userAgent)) this.plat_chrome=true;
this.plat_mac = /^Mac/.test(navigator.platform);
try { this.nonGMmode= (typeof GM == "undefined"); } // || "Barychelidae"!=GM_getValue("arachnoidal","Barychelidae"); }
catch(e) { this.nonGMmode=true; }; //eg, chromium stadalone
//this.nonjQ = !window.jQuery || parseFloat(jQuery.fn.jquery) < 3.1;
if (nonGMmode){ // chromium bare, ie, w/o tamper.
console.info("SVAB userscript in non GM_ mode at "+location.href, "typeof GM:",typeof GM, "nonGMmode",nonGMmode);
this.unsafeWindow=window;
this.old_GM_getValue=this.GM_getValue;
try { localStorage["anothervariable"]=32; } catch(e) {
window.nostorage=true;
if(!iframe) console.error("No local storage, no GM storage, use Tampermonkey to include this script on page:",location.href);
window.localStorage={};
}
if(!window.nostorage) console.log("Have local storage",localStorage.anothervariable);
this.GM_getValue=function(a,b) { return localStorage[a]||b; };
this.GM_setValue=function(a,b) { localStorage[a]=b; };
this.GM_getResourceURL=function(url) {
var ext="Dbl"; if (url.endsWith("Orig")) ext=".orig"; else if (url.endsWith("Xsm")) ext="ExSm"; else if (url.endsWith("Trpl")) ext="Trpl";
return "https://raw.githubusercontent.com/SloaneFox/imgstore/master/whiteCurtains"+ ext +".jpg";
};
//this.GM_registerMenuCommand=x=>null;
this.GM_addStyle=function(cssSheet) { $("head").append("<style>"+cssSheet+"</style>"); };
this.uneval=function(x) { return "("+JSON.stringify(x)+")"; }; //Diff is that uneval brackets string and json excludes code only data allowed in json.
var xhr_queue=[], xhr=new XMLHttpRequest();
xhr.onload=x=> { //arrow function means this remains window not xhr (as a function would).
console.log(xhr.responseURL,"onload to eval in window, jQuery in window? ",!!window.jQuery,!!window.$,!!this.jQuery);
var synop=(xhr.response||"").substr(0,40);
try {
eval.call(window,xhr.response); } catch(e) { console.error("Can't eval Error:"+e,". Response:",xhr.response?xhr.response.substr(0,60)+"[60chars]":"No response text",x,xhr,", Queue:",xhr_queue); }
if (xhr_queue.length) { xhr.open('GET', xhr_queue.shift()); xhr.send(); }
else cback(); //////////////////
// else if (!iframe) main.call(window); //////////////////
};
xhr.onerror=e=> {
console.log("W/e XHR Error: "+e,", E:",e,"XHR:",xhr,"After error queue:",xhr_queue);
if (xhr_queue.length) xhr.open('GET', xhr_queue.shift()); xhr.send();
};
var jq_versions_prior={
core: parseFloat(this.$ && this.$.fn && this.$.fn.jquery) || 0,
ui: parseFloat(this.$ && this.$.ui && this.$.ui.version) || 0
};
if(jq_versions_prior.core < 1.7)
xhr_queue.push("https://code.jquery.com/jquery-1.7.2.js");
if(jq_versions_prior.ui < 1.12)
xhr_queue.push("https://code.jquery.com/ui/1.12.1/jquery-ui.js");
xhr_queue.push("https://raw.githubusercontent.com/SloaneFox/code/master/gm4-polyfill.js");
xhr_queue.push("https://raw.githubusercontent.com/SloaneFox/code/master/gm-popup-menus-1.3.7.js");
xhr_queue.push("https://raw.githubusercontent.com/SloaneFox/code/master/sfs-utils-0.1.4.js");
xhr.open('GET', xhr_queue.shift()); xhr.send();
return true;
} else return false; //if (nonGM || nonJQ)
}//End environInit()