Add view_in_mpv userscript
This commit is contained in:
parent
52210442c4
commit
fe6a6c33ae
109
misc/userscripts/view_in_mpv
Executable file
109
misc/userscripts/view_in_mpv
Executable file
@ -0,0 +1,109 @@
|
|||||||
|
#!/bin/bash -e
|
||||||
|
#
|
||||||
|
# Behaviour:
|
||||||
|
# Userscript for qutebrowser which views the current web page in mpv using
|
||||||
|
# sensible mpv-flags. While viewing the page in MPV, all <video>-tags in the
|
||||||
|
# original page are temporarily removed. By clicking on such a removed video
|
||||||
|
# restores the respective video.
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
# [alias]-section of qutebrowser.conf:
|
||||||
|
#
|
||||||
|
# mpv = spawn --userscript /path/to/view_in_mpv
|
||||||
|
#
|
||||||
|
# Background:
|
||||||
|
# Most of my machines are to slow to play youtube videos using html5, but
|
||||||
|
# they work fine in mpv (and mpv has further advantages like video scaling,
|
||||||
|
# etc). Of course, I don't want the video to be played (or even to be
|
||||||
|
# downloaded) twice — in MPV and in qwebkit. So I often clos the tab after
|
||||||
|
# opening it in mpv. However, I actually want to keep the rest of the page
|
||||||
|
# (comments and video suggestions), i.e. only the videos should disappear
|
||||||
|
# when mpv us started. And that's precisely what the present script does.
|
||||||
|
#
|
||||||
|
# Thorsten Wißmann, 2015 (thorsten` on freenode)
|
||||||
|
# Any feedback is welcome!
|
||||||
|
|
||||||
|
msg() {
|
||||||
|
local cmd="$1"
|
||||||
|
shift
|
||||||
|
local msg="$*"
|
||||||
|
if [ -z "$QUTE_FIFO" ] ; then
|
||||||
|
echo "$cmd: $msg" >&2
|
||||||
|
else
|
||||||
|
echo "message-$cmd '${msg//\'/\\\'}'" >> "$QUTE_FIFO"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
MPV_COMMAND=${MPV_COMMAND:-mpv}
|
||||||
|
# Warning: spaces in single flags are not supported
|
||||||
|
MPV_FLAGS=${MPV_FLAGS:- --force-window --no-terminal --keep-open=yes --ytdl }
|
||||||
|
video_command=( "$MPV_COMMAND" $MPV_FLAGS )
|
||||||
|
|
||||||
|
js() {
|
||||||
|
cat <<EOF
|
||||||
|
|
||||||
|
var App = {};
|
||||||
|
|
||||||
|
var all_videos = document.getElementsByTagName("video");
|
||||||
|
App.backup_videos = Array();
|
||||||
|
App.all_replacements = Array();
|
||||||
|
for (i = 0; i < all_videos.length; i++) {
|
||||||
|
var video = all_videos[i];
|
||||||
|
var replacement = document.createElement("div");
|
||||||
|
replacement.innerHTML = "
|
||||||
|
<p style=\\"margin-bottom: 0.5em\\">
|
||||||
|
Opening page with:
|
||||||
|
<span style=\\"font-family: monospace;\\">${video_command[*]}</span>
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
In order to restore this particular video
|
||||||
|
<a style=\\"font-weight: bold;
|
||||||
|
color: white;
|
||||||
|
\\"
|
||||||
|
onClick=\\"restore_video(this, " + i + ");\\"
|
||||||
|
href=\\"javascript: restore_video(this, " + i + ")\\"
|
||||||
|
>click here</a>.
|
||||||
|
</p>
|
||||||
|
";
|
||||||
|
replacement.style.position = "relative";
|
||||||
|
replacement.style.zIndex = "1000";
|
||||||
|
replacement.style.fontSize = "1rem";
|
||||||
|
replacement.style.textAlign = "center";
|
||||||
|
replacement.style.verticalAlign = "middle";
|
||||||
|
replacement.style.height = "100%";
|
||||||
|
replacement.style.background = "#101010";
|
||||||
|
replacement.style.color = "white";
|
||||||
|
replacement.style.border = "4px dashed #545454";
|
||||||
|
replacement.style.padding = "2em";
|
||||||
|
replacement.style.margin = "auto";
|
||||||
|
App.all_replacements[i] = replacement;
|
||||||
|
App.backup_videos[i] = video;
|
||||||
|
video.parentNode.replaceChild(replacement, video);
|
||||||
|
}
|
||||||
|
|
||||||
|
function restore_video(obj, index) {
|
||||||
|
obj = App.all_replacements[index];
|
||||||
|
video = App.backup_videos[index];
|
||||||
|
console.log(video);
|
||||||
|
obj.parentNode.replaceChild(video, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** force repainting the video, thanks to:
|
||||||
|
* http://martinwolf.org/2014/06/10/force-repaint-of-an-element-with-javascript/
|
||||||
|
*/
|
||||||
|
var siteHeader = document.getElementById('header');
|
||||||
|
siteHeader.style.display='none';
|
||||||
|
siteHeader.offsetHeight; // no need to store this anywhere, the reference is enough
|
||||||
|
siteHeader.style.display='block';
|
||||||
|
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
printjs() {
|
||||||
|
js | sed 's,//.*$,,' | tr '\n' ' '
|
||||||
|
}
|
||||||
|
echo "jseval -q $(printjs)" >> "$QUTE_FIFO"
|
||||||
|
|
||||||
|
msg info "Openning $QUTE_URL with mpv"
|
||||||
|
"${video_command[@]}" "$QUTE_URL"
|
Loading…
Reference in New Issue
Block a user