Also hide <embed> tags

But only hide those tags that aren't children (or descendants) of other
tags that get replaced anyway. That is needed because sometimes, flash
videos are in <embed> tags, sometimgs in <object> tags and sometimes in
<embed> tags within <object> tags.

Furthermore enforce our "click here" link to have transparent background
(and in future: remove as many properties from website specific CSS
stylesheets).
This commit is contained in:
Thorsten Wißmann 2015-09-03 16:33:49 +02:00
parent e5b7fdb565
commit de5cdf6f0f

View File

@ -2,9 +2,9 @@
# #
# Behaviour: # Behaviour:
# Userscript for qutebrowser which views the current web page in mpv using # Userscript for qutebrowser which views the current web page in mpv using
# sensible mpv-flags. While viewing the page in MPV, all <video> and <object> # sensible mpv-flags. While viewing the page in MPV, all <video>, <embed>,
# tags in the original page are temporarily removed. Clicking on such a # and <object> tags in the original page are temporarily removed. Clicking on
# removed video restores the respective video. # such a removed video restores the respective video.
# #
# In order to use this script, just start it using `spawn --userscript` from # In order to use this script, just start it using `spawn --userscript` from
# qutebrowser. I recommend using an alias, e.g. put this in the # qutebrowser. I recommend using an alias, e.g. put this in the
@ -43,15 +43,34 @@ video_command=( "$MPV_COMMAND" $MPV_FLAGS )
js() { js() {
cat <<EOF cat <<EOF
function descendantOfTagName(child, ancestorTagName) {
// tells whether child has some (proper) ancestor
// with the tag name ancestorTagName
while (child.parentNode != null) {
child = child.parentNode;
if (typeof child.tagName === 'undefined') break;
if (child.tagName.toUpperCase() == ancestorTagName.toUpperCase()) {
return true;
}
}
return false;
}
var App = {}; var App = {};
var all_videos = []; var all_videos = [];
all_videos.push.apply(all_videos, document.getElementsByTagName("video")); all_videos.push.apply(all_videos, document.getElementsByTagName("video"));
all_videos.push.apply(all_videos, document.getElementsByTagName("object")); all_videos.push.apply(all_videos, document.getElementsByTagName("object"));
all_videos.push.apply(all_videos, document.getElementsByTagName("embed"));
App.backup_videos = Array(); App.backup_videos = Array();
App.all_replacements = Array(); App.all_replacements = Array();
for (i = 0; i < all_videos.length; i++) { for (i = 0; i < all_videos.length; i++) {
var video = all_videos[i]; var video = all_videos[i];
if (descendantOfTagName(video, "object")) {
// skip tags that are contained in an object, because we hide
// the object anyway.
continue;
}
var replacement = document.createElement("div"); var replacement = document.createElement("div");
replacement.innerHTML = " replacement.innerHTML = "
<p style=\\"margin-bottom: 0.5em\\"> <p style=\\"margin-bottom: 0.5em\\">
@ -62,6 +81,7 @@ cat <<EOF
In order to restore this particular video In order to restore this particular video
<a style=\\"font-weight: bold; <a style=\\"font-weight: bold;
color: white; color: white;
background: transparent;
\\" \\"
onClick=\\"restore_video(this, " + i + ");\\" onClick=\\"restore_video(this, " + i + ");\\"
href=\\"javascript: restore_video(this, " + i + ")\\" href=\\"javascript: restore_video(this, " + i + ")\\"