NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name YouTube Popout Button // @description Provides a button to pop out the YouTube video in a separate window. // @version 1.1.1 // @author joeytwiddle // @contributor Alek_T, tehnicallyrite // @license ISC // @include http://*.youtube.com/watch* // @include http://youtube.com/watch* // @include https://*.youtube.com/watch* // @include https://youtube.com/watch* // @grant none // ==/UserScript== // This is a combination of two scripts I found: // - http://userscripts-mirror.org/scripts/show/75815#YouTube:_Pop-out_Video // - http://userscripts-mirror.org/scripts/show/69687#YouTube_Popout // For a while I think I hosted it here (but it never got mirrored): // - http://userscripts-mirror.org/scripts/show/150631#YouTube_Popout_Button // Need to delay, or the target div won't be rendered yet setTimeout(function() { // Create Button var divWatchHeadline = document.evaluate("//div[@id='watch-actions']", document, null, XPathResult.ANY_UNORDERED_NODE_TYPE, null).singleNodeValue; divWatchHeadline = divWatchHeadline || document.getElementById("watch7-secondary-actions"); divWatchHeadline = divWatchHeadline || document.getElementById("watch8-secondary-actions"); divWatchHeadline = divWatchHeadline || document.querySelector("#menu .ytd-video-primary-info-renderer"); //divWatchHeadline = divWatchHeadline || document.querySelector("#top-level-buttons"); var buttonPopout = document.createElement("button"); buttonPopout.title = "Pop-out Video"; //buttonPopout.setAttribute("class", "yt-uix-button yt-uix-button-default yt-uix-tooltip"); buttonPopout.style.background = 'transparent'; buttonPopout.style.border = 'none'; buttonPopout.style.cursor = 'pointer'; buttonPopout.setAttribute("data-tooltip-title", "Pop-out Video"); var popoutImage = document.createElement("img"); var offButton = ""; var overButton = ""; popoutImage.src = offButton; popoutImage.setAttribute("alt", "External link icon"); popoutImage.setAttribute("style", "padding:0px 0px 2px 1px;"); buttonPopout.appendChild(popoutImage); // The other buttons don't change these days, so we won't either //buttonPopout.addEventListener("mouseover", function() { popoutImage.src = overButton; }, false); //buttonPopout.addEventListener("mouseout", function() { popoutImage.src = offButton; }, false); //divWatchHeadline.appendChild(document.createTextNode("\n")); //divWatchHeadline.appendChild(buttonPopout); divWatchHeadline.insertBefore(buttonPopout, divWatchHeadline.lastElementChild); //divWatchHeadline.appendChild(document.createTextNode("\n")); buttonPopout.addEventListener("click", popOutVideo, false); function popOutVideo() { // Grabbing Video Id function gup(name) { name = name.replace(/[\[]/, "\\\[").replace(/[\]]/, "\\\]"); var regexS = "[\\?&]" + name + "=([^&#]*)"; var regex = new RegExp(regexS); var results = regex.exec(window.location.href); return results && results[1]; } var ytvidid = gup('v'); if (ytvidid) { //var link = "http://www.youtube.com/watch_popup?v="; //var flink = link+ytvidid; // The above URL gets redirected to https://www.youtube.com/embed/bNcWVUfwmS4&autoplay=1#at=6 // And the redirect causes autoplay to not work. So let's go directly to the target URL. var flink = "https://www.youtube.com/embed/" + ytvidid + "?autoplay=1"; var lcheck = location.href; // I think this used to prevent infinite loops when the script was auto-forwarding if (lcheck !== flink) { try { var player = window.document.getElementById('movie_player'); if (player) { // If we are in Greasemonkey's sandbox, we need to get out! if (player.wrappedJSObject) { player = player.wrappedJSObject; } player.pauseVideo(); var time = player.getCurrentTime(); flink += "#at=" + (time | 0); } } catch (e) { console.error("" + e); } // window.location = flink; // Change "YoutubePopout" to "_blank" if you want new popouts to appear in a separate window from the existing popout. window.open(flink, "YoutubePopout", "menubar=no,location=no,resizable=yes,status=no,toolbar=no,personalbar=no"); } } } }, 4000);