Display "https://www.youtube.com/watch?v=***********" of embedded YouTube videos.
目前為
// ==UserScript==
// @name video watch page URL
// @name:ja 埋め込み動画にURL表示
// @namespace https://greasyfork.org/users/19523
// @description Display "https://www.youtube.com/watch?v=***********" of embedded YouTube videos.
// @description:ja ページに埋め込まれたYouTubeの動画の下に動画視聴ページのURLを付け加えます
// @include *
// @exclude http://www.youtube.com/*
// @exclude https://www.youtube.com/*
// @version 0.3.3
// @grant none
// ==/UserScript==
(function () {
var style = document.createElement('style');
style.type = 'text/css';
style.appendChild(document.createTextNode('' +
'a.youtube-url {' +
'position: relative;' +
'display: table;' +
'font-size: initial;' +
'}'));
document.getElementsByTagName('head')[0].appendChild(style);
try {
var target = document.body;
var config = { childList: true, subtree: true };
var observer = new MutationObserver(function (mutations) {
insertURL();
});
} catch(e) {
if (window.top != window.self) {
return;
}
var observer = { disconnect: function () {}, observe: function () {} };
var elementCounts = document.querySelectorAll('*').length;
function observeLength() {
if (elementCounts != document.querySelectorAll('*').length) {
elementCounts = document.querySelectorAll('*').length;
insertURL();
}
return;
}
setInterval(function () { observeLength(); }, 5000);
}
window.addEventListener('load', insertURL);
function insertURL() {
observer.disconnect();
var elements = document.querySelectorAll('iframe[src*="//www.youtube.com/embed/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
if (element.src.indexOf('videoseries') >= 0) {
a.href = element.src.replace(/embed\/videoseries/, 'playlist');
} else {
a.href = element.src.split('?')[0].replace(/embed\//, 'watch?v=');
}
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
if (element.parentElement.children.length <= 2 && element.parentElement != document.body && element.parentElement.parentElement) {
element = element.parentElement;
}
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].src);
}
var elements = document.querySelectorAll('iframe[src*="//www.youtube-nocookie.com/embed/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
if (element.src.indexOf('videoseries') >= 0) {
a.href = element.src.replace(/-nocookie\.com\/embed\/videoseries/, '.com/playlist');
} else {
a.href = element.src.split('?')[0].replace(/-nocookie\.com\/embed\//, '.com/watch?v=');
}
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
if (element.parentElement.children.length <= 2 && element.parentElement != document.body && element.parentElement.parentElement) {
element = element.parentElement;
}
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].src);
}
var elements = document.querySelectorAll('iframe[data-src*="//www.youtube.com/embed/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
if (element.getAttribute('data-src').indexOf('videoseries') >= 0) {
a.href = element.getAttribute('data-src').replace(/embed\/videoseries/, 'playlist');
} else {
a.href = element.getAttribute('data-src').split('?')[0].replace(/embed\//, 'watch?v=');
}
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
if (element.parentElement.children.length <= 2 && element.parentElement != document.body && element.parentElement.parentElement) {
element = element.parentElement;
}
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].getAttribute('data-src'));
}
var elements = document.querySelectorAll('iframe[data-src*="//www.youtube-nocookie.com/embed/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
if (element.getAttribute('data-src').indexOf('videoseries') >= 0) {
a.href = element.getAttribute('data-src').replace(/-nocookie\.com\/embed\/videoseries/, '.com/playlist');
} else {
a.href = element.getAttribute('data-src').split('?')[0].replace(/-nocookie\.com\/embed\//, '.com/watch?v=');
}
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
if (element.parentElement.children.length <= 2 && element.parentElement != document.body && element.parentElement.parentElement) {
element = element.parentElement;
}
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].getAttribute('data-src'));
}
// Flash-embedded videos
var elements = document.querySelectorAll('embed[src*="//www.youtube.com/v/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
a.href = element.src.split('?')[0].replace(/v\//, 'watch?v=');
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].src);
}
var elements = document.querySelectorAll('embed[src*="//www.youtube-nocookie.com/v/"]:not([class~="youtube-url"])');
for (var i = 0, element; element = elements[i]; i++) {
var a = document.createElement('a');
a.href = element.src.split('?')[0].replace(/-nocookie\.com\/v\//, '.com/watch?v=');
a.appendChild(document.createTextNode(a.href));
element.className += a.className = ' youtube-url';
element.parentElement.insertBefore(a, element.nextSibling);
console.log('Detected URL: %s', elements[i].src);
}
observer.observe(target, config);
}
})();