Created
August 20, 2017 16:56
-
-
Save mikhoul/41122d22b9e731400b164a3ed8344d8e to your computer and use it in GitHub Desktop.
Doctored Version to remove embedding.
This file has been truncated, but you can view the full file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
The MIT License (MIT) | |
Copyright © 2015 Jeppe Rune Mortensen | |
Permission is hereby granted, free of charge, to any person obtaining a copy of | |
this software and associated documentation files (the "Software"), to deal in | |
the Software without restriction, including without limitation the rights to | |
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of | |
the Software, and to permit persons to whom the Software is furnished to do so, | |
subject to the following conditions: | |
The above copyright notice and this permission notice shall be included in all | |
copies or substantial portions of the Software. | |
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS | |
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR | |
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER | |
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | |
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
**/ | |
// ==UserScript== | |
// @id YouTubeCenter Mikhoul Hack to revove embedded | |
// @name YouTube Center Developer Build - Mikhoul Hack to revove embedded | |
// @namespace http://www.facebook.com/YouTubeCenter | |
// @version 548.01 | |
// @author Jeppe Rune Mortensen <jepperm@gmail.com> | |
// @description YouTube Center Developer Build contains all kind of different useful functions which makes your visit on YouTube much more entertaining. | |
// @icon https://raw.github.com/YePpHa/YouTubeCenter/master/assets/icon48.png | |
// @icon64 https://raw.github.com/YePpHa/YouTubeCenter/master/assets/icon64.png | |
// @domain yeppha.github.io | |
// @domain youtube.com | |
// @domain www.youtube.com | |
// @domain gdata.youtube.com | |
// @domain apis.google.com | |
// @domain plus.googleapis.com | |
// @domain googleapis.com | |
// @domain raw.github.com | |
// @domain raw2.github.com | |
// @domain raw.githubusercontent.com | |
// @domain s.ytimg.com | |
// @match http://www.youtube.com/* | |
// @match https://www.youtube.com/* | |
// @match http://youtube.com/* | |
// @match https://youtube.com/* | |
// @match https://yeppha.github.io/downloads/YouTubeCenter.meta.js | |
// @match http://s.ytimg.com/yts/jsbin/* | |
// @match https://s.ytimg.com/yts/jsbin/* | |
// @match https://raw.github.com/YePpHa/YouTubeCenter/master/* | |
// @match https://raw.githubusercontent.com/YePpHa/YouTubeCenter/master/* | |
// @match http://raw.github.com/YePpHa/YouTubeCenter/master/* | |
// @match http://raw.githubusercontent.com/YePpHa/YouTubeCenter/master/* | |
// @match http://apis.google.com/*/widget/render/comments?* | |
// @match https://apis.google.com/*/widget/render/comments?* | |
// @match http://plus.googleapis.com/*/widget/render/comments?* | |
// @match https://plus.googleapis.com/*/widget/render/comments?* | |
// @include http://www.youtube.com/* | |
// @include https://www.youtube.com/* | |
// @include http://youtube.com/* | |
// @include https://youtube.com/* | |
// @include http://apis.google.com/*/widget/render/comments?* | |
// @include https://apis.google.com/*/widget/render/comments?* | |
// @include http://plus.googleapis.com/*/widget/render/comments?* | |
// @include https://plus.googleapis.com/*/widget/render/comments?* | |
// @exclude http://apiblog.youtube.com/* | |
// @exclude https://apiblog.youtube.com/* | |
// @exclude http://*.youtube.com/subscribe_embed?* | |
// @exclude https://*.youtube.com/subscribe_embed?* | |
// @grant GM_getValue | |
// @grant GM_setValue | |
// @grant GM_xmlhttpRequest | |
// @grant GM_log | |
// @grant GM_registerMenuCommand | |
// @grant unsafeWindow | |
// @updateURL https://github.com/YePpHa/YouTubeCenter/raw/master/dist/YouTubeCenter.meta.js | |
// @downloadURL https://github.com/YePpHa/YouTubeCenter/raw/master/dist/YouTubeCenter.user.js | |
// @updateVersion 155 | |
// @run-at document-start | |
// @priority 9001 | |
// @homepageURL https://github.com/YePpHa/YouTubeCenter/wiki | |
// @contributionURL https://github.com/YePpHa/YouTubeCenter/wiki/Donate | |
// @supportURL https://github.com/YePpHa/YouTubeCenter/issues | |
// @license MIT | |
// ==/UserScript== | |
(function(){ | |
"use strict"; | |
function inject(func, bypass) { | |
if (hasInjected && !bypass) return; | |
hasInjected = true; | |
injectScript(func); | |
} | |
function injectScript(func, filename, noArgs) { | |
filename = filename || "YouTubeCenter.js"; | |
var script = document.createElement("script"); | |
var parent = document.body || document.head || document.documentElement; | |
if (!parent) { | |
setTimeout(bind(null, injectScript, func, true), 0); | |
return; | |
} | |
script.setAttribute("type", "text/javascript"); | |
if (typeof func === "string") { | |
func = "function(){" + func + "}"; | |
} | |
var fn = "(" + func + ")"; | |
if (noArgs) { | |
fn += "()"; | |
} else { | |
fn += "(true, 0, true, 548)"; | |
} | |
script.appendChild(document.createTextNode(fn + ";\n//# sourceURL=" + filename)); | |
parent.appendChild(script); | |
parent.removeChild(script); | |
} | |
function bind(scope, func) { | |
var args = Array.prototype.slice.call(arguments, 2); | |
return function(){ | |
return func.apply(scope, args.concat(Array.prototype.slice.call(arguments))) | |
}; | |
} | |
function getNavigator() { | |
try { | |
if (window && typeof window.navigator === "object") { | |
return window.navigator; | |
} else if (typeof navigator === "object") { | |
return navigator; | |
} | |
} catch (e) { | |
return { /* empty */ }; | |
} | |
} | |
function isCookieEnabled() { | |
try { | |
var cookieEnabled = getNavigator().cookieEnabled; | |
if (cookieEnabled === false) return false; | |
setCookie("ytc_cookie_test", "testing", ".youtube.com", "/", 3600*60*24*30); | |
var isEnabled = getCookie("ytc_cookie_test") === "testing"; | |
// Removing the test cookie | |
setCookie("ytc_cookie_test", null, ".youtube.com", "/", 0); | |
return isEnabled; | |
} catch (e) { | |
return false; | |
} | |
} | |
function setCookie(name, value, domain, path, expires) { | |
domain = domain ? ";domain=" + encodeURIComponent(domain) : ""; | |
path = path ? ";path=" + encodeURIComponent(path) : ""; | |
expires = 0 > expires ? "" : 0 == expires ? ";expires=" + (new Date(1970, 1, 1)).toUTCString() : ";expires=" + (new Date(now() + 1E3 * expires)).toUTCString(); | |
document.cookie = encodeURIComponent(name) + "=" + encodeURIComponent(value) + domain + path + expires; | |
} | |
function getCookie(key) { | |
return getCookies()[key]; | |
} | |
function getCookies() { | |
function trimLeft(obj){ | |
return obj.replace(/^\s+/, ""); | |
} | |
function trimRight(obj){ | |
return obj.replace(/\s+$/, ""); | |
} | |
function map(obj, callback, thisArg) { | |
for (var i = 0, n = obj.length, a = []; i < n; i++) { | |
if (i in obj) a[i] = callback.call(thisArg, obj[i]); | |
} | |
return a; | |
} | |
var c = document.cookie, v = 0, cookies = {}; | |
if (document.cookie.match(/^\s*\$Version=(?:"1"|1);\s*(.*)/)) { | |
c = RegExp.$1; | |
v = 1; | |
} | |
if (v === 0) { | |
map(c.split(/[,;]/), function(cookie) { | |
var parts = cookie.split(/=/, 2), | |
name = decodeURIComponent(trimLeft(parts[0])), | |
value = parts.length > 1 ? decodeURIComponent(trimRight(parts[1])) : null; | |
cookies[name] = value; | |
}); | |
} else { | |
map(c.match(/(?:^|\s+)([!#$%&'*+\-.0-9A-Z^`a-z|~]+)=([!#$%&'*+\-.0-9A-Z^`a-z|~]*|"(?:[\x20-\x7E\x80\xFF]|\\[\x00-\x7F])*")(?=\s*[,;]|$)/g), function($0, $1) { | |
var name = $0, | |
value = $1.charAt(0) === '"' | |
? $1.substr(1, -1).replace(/\\(.)/g, "$1") | |
: $1; | |
cookies[name] = value; | |
}); | |
} | |
return cookies; | |
} | |
function isEmbeddedVideo() { | |
return !!loc.href.match(/^http(s)?:\/\/(www\.)?youtube\.com\/ZZZembed\//) || !!loc.href.match(/^http(s)?:\/\/(www\.)?youtube\.com\/ZZZwatch_popup\?\//); | |
} | |
var main_function = function(injected, identifier, devbuild, devnumber, _unsafeWindow, preloadedSettings, undefined){ | |
"use strict"; | |
/* UTILS */ | |
function $UpdateChecker() { | |
if (!ytcenter.settings.enableUpdateChecker) return; | |
var curr = (new Date().getTime()), | |
c = curr - 1000*60*60*parseInt(ytcenter.settings.updateCheckerInterval); | |
con.log("Checking for updates in " + ((ytcenter.settings.updateCheckerLastUpdate - c)/1000/60/60) + " hours..."); | |
if (c >= ytcenter.settings.updateCheckerLastUpdate) { | |
con.log("Checking for updates now..."); | |
ytcenter.settings.updateCheckerLastUpdate = curr; | |
ytcenter.saveSettings(); | |
ytcenter.checkForUpdates(); | |
} | |
} | |
function $CreateAspectButton() { | |
var btn = document.createElement("button"); | |
btn.className = "yt-uix-button yt-uix-tooltip" + (ytcenter.settings.aspectEnable ? "" : " hid") + (!ytcenter.watch7 ? " yt-uix-button-default" : " yt-uix-button-text"); | |
btn.setAttribute("title", ytcenter.language.getLocale("BUTTON_ASPECT_TOOLTIP")); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("role", "button"); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
btn.setAttribute("title", ytcenter.language.getLocale("BUTTON_ASPECT_TOOLTIP")); | |
if (ytcenter.settings.aspectEnable) { | |
ytcenter.utils.removeClass(btn, "hid"); | |
} else { | |
ytcenter.utils.addClass(btn, "hid"); | |
} | |
}); | |
var btnContent = document.createElement("span"); | |
btnContent.className = "yt-uix-button-content"; | |
btnContent.textContent = ytcenter.language.getLocale("BUTTON_ASPECT_TEXT"); | |
ytcenter.language.addLocaleElement(btnContent, "BUTTON_ASPECT_TEXT", "@textContent"); | |
btn.appendChild(btnContent); | |
var arrow = document.createElement("img"); | |
arrow.className = "yt-uix-button-arrow"; | |
arrow.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
arrow.setAttribute("alt", ""); | |
btn.appendChild(arrow); | |
var groups = { | |
'crop': 'BUTTON_ASPECT_CROP', | |
'stretch': 'BUTTON_ASPECT_STRETCH' | |
}; | |
var groupChoices = { | |
'4:3': 'BUTTON_ASPECT_4:3', | |
'3:2': 'BUTTON_ASPECT_3:2', | |
'16:9': 'BUTTON_ASPECT_16:9' | |
}; | |
var menu = document.createElement("ul"); | |
menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid"; | |
menu.setAttribute("role", "menu"); | |
menu.setAttribute("aria-haspopup", "true"); | |
var playerAspectTMP = ytcenter.settings['aspectValue']; | |
var item; | |
item = document.createElement("span"); | |
if (ytcenter.settings.aspectValue === "none") { | |
item.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
} | |
item.className = "yt-uix-button-menu-item"; | |
item.setAttribute("onclick", ";return false;"); | |
item.textContent = ytcenter.language.getLocale("BUTTON_ASPECT_NONE"); | |
ytcenter.language.addLocaleElement(item, "BUTTON_ASPECT_NONE", "@textContent"); | |
ytcenter.utils.addEventListener(item, "click", function(){ | |
playerAspectTMP = "none"; | |
if (ytcenter.settings.aspectSave) { | |
ytcenter.settings['aspectValue'] = "none"; | |
} | |
for (var i = 0; i < this.parentNode.parentNode.children.length; i++) { | |
if (this.parentNode.parentNode.children[i].children[0] && this.parentNode.parentNode.children[i].children[0].tagName === "SPAN") { | |
this.parentNode.parentNode.children[i].children[0].setAttribute("style", ""); | |
} | |
} | |
this.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
ytcenter.saveSettings(); | |
ytcenter.player.aspect("none"); | |
}, false); | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
item = document.createElement("span"); | |
if (ytcenter.settings.aspectValue === "default") { | |
item.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
} | |
item.className = "yt-uix-button-menu-item"; | |
item.setAttribute("onclick", ";return false;"); | |
item.textContent = ytcenter.language.getLocale("BUTTON_ASPECT_DEFAULT"); | |
ytcenter.utils.addEventListener(item, "click", function(){ | |
playerAspectTMP = "default"; | |
if (ytcenter.settings.aspectSave) { | |
ytcenter.settings['aspectValue'] = "default"; | |
} | |
for (var i = 0; i < this.parentNode.parentNode.children.length; i++) { | |
if (this.parentNode.parentNode.children[i].children[0] && this.parentNode.parentNode.children[i].children[0].tagName === "SPAN") { | |
this.parentNode.parentNode.children[i].children[0].setAttribute("style", ""); | |
} | |
} | |
this.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
ytcenter.saveSettings(); | |
ytcenter.player.aspect("default"); | |
}, false); | |
ytcenter.language.addLocaleElement(item, "BUTTON_ASPECT_DEFAULT", "@textContent"); | |
li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
for (var group in groups) { | |
if (groups.hasOwnProperty(group)) { | |
item = document.createElement("li"); | |
item.style.fontWeight = "bold"; | |
item.style.padding = "6px"; | |
item.textContent = ytcenter.language.getLocale(groups[group]); | |
ytcenter.language.addLocaleElement(item, groups[group], "@textContent"); | |
menu.appendChild(item); | |
for (var child in groupChoices) { | |
if (groupChoices.hasOwnProperty(child)) { | |
if (child === "4:3" && group === "crop") continue; | |
var val = "yt:" + group + "=" + child; | |
item = document.createElement("span"); | |
if (val === ytcenter.settings.aspectValue) { | |
item.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
} | |
item.className = "yt-uix-button-menu-item"; | |
item.setAttribute("role", "menuitem"); | |
item.setAttribute("onclick", ";return false;"); | |
item.textContent = ytcenter.language.getLocale(groupChoices[child]); | |
ytcenter.language.addLocaleElement(item, groupChoices[child], "@textContent"); | |
ytcenter.utils.addEventListener(item, "click", (function(val, group, child){ | |
return function(){ | |
var val = "yt:" + group + "=" + child; | |
playerAspectTMP = val; | |
if (ytcenter.settings.aspectSave) { | |
ytcenter.settings['aspectValue'] = val; | |
} | |
for (var i = 0; i < this.parentNode.parentNode.children.length; i++) { | |
if (this.parentNode.parentNode.children[i].children[0] && this.parentNode.parentNode.children[i].children[0].tagName === "SPAN") { | |
this.parentNode.parentNode.children[i].children[0].setAttribute("style", ""); | |
} | |
} | |
this.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
ytcenter.saveSettings(); | |
ytcenter.player.aspect(val); | |
}; | |
})(val, group, child), false); | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
} | |
} | |
if (group === "crop") { | |
var val = "yt:" + group + "=24:10"; | |
item = document.createElement("span"); | |
if (val === ytcenter.settings.aspectValue) { | |
item.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
} | |
item.className = "yt-uix-button-menu-item"; | |
item.setAttribute("role", "menuitem"); | |
item.setAttribute("onclick", ";return false;"); | |
item.textContent = ytcenter.language.getLocale("BUTTON_ASPECT_24:10"); | |
ytcenter.language.addLocaleElement(item, "BUTTON_ASPECT_24:10", "@textContent"); | |
ytcenter.utils.addEventListener(item, "click", (function(val, group, child){ | |
return function(){ | |
var val = "yt:" + group + "=24:10"; | |
playerAspectTMP = val; | |
if (ytcenter.settings.aspectSave) { | |
ytcenter.settings['aspectValue'] = val; | |
} | |
for (var i = 0; i < this.parentNode.parentNode.children.length; i++) { | |
if (this.parentNode.parentNode.children[i].children[0] && this.parentNode.parentNode.children[i].children[0].tagName === "SPAN") { | |
this.parentNode.parentNode.children[i].children[0].setAttribute("style", ""); | |
} | |
} | |
this.setAttribute("style", "background:#555!important;color:#FFF!important;"); | |
ytcenter.saveSettings(); | |
ytcenter.player.aspect(val); | |
}; | |
})(val, group, child), false); | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
} | |
} | |
} | |
item = document.createElement("div"); | |
item.style.padding = "7px 9px 0 9px"; | |
item.style.borderTop = "1px #555 solid"; | |
var itemLabel = document.createElement("label"); | |
var label = document.createTextNode(ytcenter.language.getLocale("SETTINGS_ASPECT_REMEMBER")); | |
itemLabel.appendChild(label); | |
ytcenter.language.addLocaleElement(label, "SETTINGS_ASPECT_REMEMBER", "@textContent"); | |
var itemCheckbox = $CreateCheckbox(ytcenter.settings.aspectSave); | |
itemCheckbox.style.marginLeft = "3px"; | |
ytcenter.utils.addEventListener(itemLabel, "click", function(){ | |
ytcenter.settings.aspectSave = !ytcenter.settings.aspectSave; | |
if (ytcenter.settings.aspectSave) { | |
ytcenter.utils.addClass(itemCheckbox, "checked"); | |
ytcenter.settings.aspectValue = playerAspectTMP; | |
} else { | |
ytcenter.utils.removeClass(itemCheckbox, "checked"); | |
} | |
ytcenter.saveSettings(); | |
}, false); | |
itemLabel.appendChild(itemCheckbox); | |
item.appendChild(itemLabel); | |
menu.appendChild(item); | |
btn.appendChild(menu); | |
ytcenter.placementsystem.addElement("ytcenter", "aspectbtn", btn); | |
} | |
function $CreateResizeButton() { | |
function getItemTitle(item) { | |
var dim = ytcenter.utils.calculateDimensions(item.config.width, item.config.height); | |
if (typeof item.config.customName !== "undefined" && item.config.customName !== "") { | |
return item.config.customName; | |
} else if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")); | |
} else { | |
return dim[0] + "×" + dim[1]; | |
} | |
} | |
function getItemSubText(item) { | |
if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} else { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} | |
} | |
function setValue(id) { | |
var item; | |
ytcenter.utils.each(ytcenter.settings["resize-playersizes"], function(i, val){ | |
if (val.id !== ytcenter.player.currentResizeId) return; | |
item = val; | |
return false; | |
}); | |
} | |
function updateItems(items) { | |
menu.innerHTML = ""; | |
var db = []; | |
ytcenter.utils.each(items, function(i, item){ | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
var span = document.createElement("span"); | |
db.push(span); | |
span.className = "yt-uix-button-menu-item" + (ytcenter.player.currentResizeId === item.id ? " ytcenter-resize-dropdown-selected" : ""); | |
span.style.paddingBottom = "12px"; | |
if (ytcenter.player.currentResizeId === item.id) { | |
setValue(ytcenter.player.currentResizeId); | |
} | |
var title = document.createElement("span"); | |
title.textContent = getItemTitle(item); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
title.textContent = getItemTitle(item); | |
}); | |
title.style.display = "block"; | |
title.style.fontWeight = "bold"; | |
var subtext = document.createElement("span"); | |
subtext.textContent = getItemSubText(item); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
subtext.textContent = getItemSubText(item); | |
}); | |
subtext.style.display = "block"; | |
subtext.style.fontSize = "11px"; | |
subtext.style.lineHeight = "0px"; | |
ytcenter.utils.addEventListener(li, "click", function(){ | |
try { | |
ytcenter.player.currentResizeId = item.id; | |
ytcenter.player.updateResize(); | |
setValue(ytcenter.player.currentResizeId); | |
try { | |
document.body.click(); | |
} catch (e) { | |
con.error(e); | |
} | |
ytcenter.utils.each(db, function(_i, elm){ | |
ytcenter.utils.removeClass(elm, "ytcenter-resize-dropdown-selected"); | |
}); | |
ytcenter.utils.addClass(span, "ytcenter-resize-dropdown-selected"); | |
} catch (e) { | |
con.error(e); | |
} | |
}); | |
span.appendChild(title); | |
span.appendChild(subtext); | |
li.appendChild(span); | |
menu.appendChild(li); | |
}); | |
} | |
var btnLabel = ytcenter.gui.createYouTubeButtonTextLabel("BUTTON_RESIZE_TEXT"); | |
var menu = document.createElement("ul"); | |
menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid"; | |
menu.setAttribute("role", "menu"); | |
var arrow = ytcenter.gui.createYouTubeButtonArrow(); | |
var btn = ytcenter.gui.createYouTubeButton("BUTTON_RESIZE_TOOLTIP", [btnLabel, arrow, menu]); | |
btn.style.textAlign = "left"; | |
if (ytcenter.settings.resizeEnable && ytcenter.settings.enableResize) { | |
ytcenter.utils.removeClass(btn, "hid"); | |
} else { | |
ytcenter.utils.addClass(btn, "hid"); | |
} | |
updateItems(ytcenter.settings["resize-playersizes"]); | |
ytcenter.events.addEvent("settings-update", function(){ | |
updateItems(ytcenter.settings["resize-playersizes"]); | |
}); | |
ytcenter.player.resizeCallback.push(function(){ | |
updateItems(ytcenter.settings["resize-playersizes"]); | |
}); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.resizeEnable && ytcenter.settings.enableResize) { | |
ytcenter.utils.removeClass(btn, "hid"); | |
} else { | |
ytcenter.utils.addClass(btn, "hid"); | |
} | |
}); | |
ytcenter.placementsystem.addElement("ytcenter", "resizebtn", btn); | |
} | |
function $CreateCheckbox(_checked) { | |
var checked = _checked || false; | |
var cont = document.createElement("span"); | |
cont.className = "yt-uix-form-input-checkbox-container" + (checked ? " checked" : ""); | |
var inp = document.createElement("input"); | |
inp.setAttribute("type", "checkbox"); | |
inp.className = "yt-uix-form-input-checkbox"; | |
inp.value = "true"; | |
if (checked) { | |
inp.checked = "checked"; | |
} | |
var span = document.createElement("span"); | |
span.className = "yt-uix-form-input-checkbox-element"; | |
cont.appendChild(inp); | |
cont.appendChild(span); | |
return cont; | |
} | |
function $CreateLightButton() { | |
var btn = document.createElement("button"); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.lightbulbEnable) { | |
ytcenter.utils.removeClass(btn, "hid"); | |
} else { | |
ytcenter.utils.addClass(btn, "hid"); | |
} | |
}); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("role", "button"); | |
btn.className = "yt-uix-button yt-uix-tooltip" + (ytcenter.settings.lightbulbEnable ? "" : " hid") + (!ytcenter.watch7 ? " yt-uix-button-default" : " yt-uix-button-text"); | |
btn.title = ytcenter.language.getLocale("LIGHTBULB_TOOLTIP"); | |
//btn.style.marginLeft = ".5em"; | |
ytcenter.language.addLocaleElement(btn, "LIGHTBULB_TOOLTIP", "title"); | |
var s = document.createElement("span"); | |
s.className = "yt-uix-button-content"; | |
var icon = document.createElement("img"); | |
icon.setAttribute("alt", ""); | |
icon.src = ytcenter.icon.lightbulb; | |
s.appendChild(icon); | |
btn.appendChild(s); | |
ytcenter.utils.addEventListener(btn, "click", function(){ | |
ytcenter.player.toggleLights(); | |
}, false); | |
ytcenter.placementsystem.addElement("ytcenter", "lightbtn", btn); | |
} | |
function $CreateRepeatButton() { | |
var btn = document.createElement("button"); | |
btn.style.margin = "0 2px 0 0"; | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.enableRepeat) { | |
ytcenter.utils.removeClass(btn, 'hid'); | |
} else { | |
ytcenter.utils.addClass(btn, 'hid'); | |
} | |
}); | |
btn.title = ytcenter.language.getLocale("BUTTON_REPEAT_TOOLTIP"); | |
ytcenter.language.addLocaleElement(btn, "BUTTON_REPEAT_TOOLTIP", "title"); | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.className = "yt-uix-button yt-uix-tooltip" + (ytcenter.settings.autoActivateRepeat ? " ytcenter-uix-button-toggled" : " yt-uix-button-text") + (ytcenter.settings.enableRepeat ? "" : " hid"); | |
ytcenter.utils.addEventListener(btn, "click", function(){ | |
if (ytcenter.doRepeat) { | |
ytcenter.utils.removeClass(this, 'ytcenter-uix-button-toggled'); | |
ytcenter.utils.addClass(this, 'yt-uix-button-text'); | |
ytcenter.doRepeat = false; | |
} else { | |
ytcenter.utils.addClass(this, 'ytcenter-uix-button-toggled'); | |
ytcenter.utils.removeClass(this, 'yt-uix-button-text'); | |
ytcenter.doRepeat = true; | |
} | |
}, false); | |
if (ytcenter.settings.autoActivateRepeat) { | |
ytcenter.doRepeat = true; | |
} else { | |
ytcenter.doRepeat = false; | |
} | |
var iconw = document.createElement("span"); | |
iconw.className = "yt-uix-button-icon-wrapper"; | |
if (!ytcenter.settings.repeatShowIcon) { | |
iconw.style.display = "none"; | |
} | |
var icon = document.createElement("img"); | |
icon.className = "yt-uix-button-icon " + (ytcenter.watch7 ? "ytcenter-repeat-icon" : "yt-uix-button-icon-playlist-bar-autoplay"); | |
icon.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
if (!ytcenter.watch7) { | |
icon.style.background = "no-repeat url(//s.ytimg.com/yts/imgbin/www-refresh-vflMaphyY.png) -173px -60px"; | |
icon.style.width = "20px"; | |
icon.style.height = "17px"; | |
} | |
/*icon.style.width = "20px"; | |
icon.style.height = "18px"; | |
icon.style.background = "no-repeat url(//s.ytimg.com/yt/imgbin/www-master-vfl8ZHa_q.png) -303px -38px";*/ | |
icon.setAttribute("alt", ""); | |
iconw.appendChild(icon); | |
btn.appendChild(iconw); | |
var t = document.createElement("span"); | |
t.className = "yt-uix-button-content"; | |
t.textContent = ytcenter.language.getLocale("BUTTON_REPEAT_TEXT"); | |
ytcenter.language.addLocaleElement(t, "BUTTON_REPEAT_TEXT", "@textContent"); | |
if (!ytcenter.settings.repeatShowText) { | |
t.style.display = "none"; | |
} | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.repeatShowIcon) { | |
iconw.style.display = ""; | |
} else { | |
iconw.style.display = "none"; | |
} | |
if (ytcenter.settings.repeatShowText) { | |
t.style.display = ""; | |
} else { | |
t.style.display = "none"; | |
} | |
}); | |
btn.appendChild(t); | |
ytcenter.placementsystem.addElement("ytcenter", "repeatbtn", btn); | |
} | |
function $DownloadButtonStream() { | |
var priority = ['small', 'medium', 'large', 'hd720', 'hd1080', 'hd1440', 'highres']; | |
var stream; | |
var format = (function(){ | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
if (ytcenter.settings.downloadFormat == ytcenter.video.format[i].key) { | |
return ytcenter.video.format[i].type; | |
} | |
} | |
return ytcenter.language.getLocale("UNKNOWN"); | |
})(); | |
for (var i = 0; i < ytcenter.video.streams.length; i++) { | |
if ((stream == null || $ArrayIndexOf(priority, ytcenter.video.streams[i].quality) > $ArrayIndexOf(priority, stream.quality)) && $ArrayIndexOf(priority, ytcenter.video.streams[i].quality) <= $ArrayIndexOf(priority, ytcenter.settings.downloadQuality) && ytcenter.video.streams[i].type && ytcenter.video.streams[i].type.indexOf(format) == 0 && ytcenter.video.streams[i].url) { | |
stream = ytcenter.video.streams[i]; | |
} | |
} | |
return stream; | |
} | |
function $CreateDownloadButton() { | |
if (identifier === 8) return; // The Chrome Webstore version of YouTube Center Developer Build has the download feature disabled. | |
var g = document.createElement("span"); | |
g.style.margin = "0 2px 0 0"; | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.enableDownload) { | |
ytcenter.utils.removeClass(g, "hid"); | |
g.style.display = ""; | |
} else { | |
ytcenter.utils.addClass(g, "hid"); | |
g.style.display = "none"; | |
} | |
}); | |
g.className = "yt-uix-button-group" + (ytcenter.settings.enableDownload ? "" : " hid"); | |
if (!ytcenter.settings.enableDownload) { | |
g.style.display = "none"; | |
} | |
var stream = $DownloadButtonStream(); | |
var btn1a = document.createElement("a"); | |
if (stream) { | |
btn1a.setAttribute("href", ytcenter.video.downloadLink(stream)); | |
btn1a.setAttribute("download", ytcenter.video.getFilename(stream) + ytcenter.video.getFilenameExtension(stream)); | |
} | |
btn1a.setAttribute("target", "_blank"); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
stream = $DownloadButtonStream(); | |
if (stream) { | |
btn1a.setAttribute("href", ytcenter.video.downloadLink(stream)); | |
btn1a.setAttribute("download", ytcenter.video.getFilename(stream) + ytcenter.video.getFilenameExtension(stream)); | |
} | |
}); | |
var btn1 = document.createElement("button"); | |
btn1.className = "start yt-uix-button yt-uix-tooltip" + (!ytcenter.watch7 ? " yt-uix-button-default" : " yt-uix-button-text"); | |
//btn1.setAttribute("onclick", ";return false;"); | |
btn1.setAttribute("type", "button"); | |
btn1.setAttribute("role", "button"); | |
ytcenter.utils.addEventListener(btn1, "click", function(e){ | |
if (!ytcenter.settings.downloadAsLinks) { | |
stream = $DownloadButtonStream(); | |
if (stream) { | |
ytcenter.video.download(stream.itag); | |
} | |
e.preventDefault(); | |
} | |
}, false); | |
if (stream != null) { | |
var stream_name = { | |
highres: ytcenter.language.getLocale("HIGHRES"), | |
hd1440: ytcenter.language.getLocale("HD1440"), | |
hd1080: ytcenter.language.getLocale("HD1080"), | |
hd720: ytcenter.language.getLocale("HD720"), | |
large: ytcenter.language.getLocale("LARGE"), | |
medium: ytcenter.language.getLocale("MEDIUM"), | |
small: ytcenter.language.getLocale("SMALL") | |
}[stream.quality]; | |
btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP"), { | |
stream_name: stream_name, | |
stream_resolution: (stream.dimension ? stream.dimension.split("x")[1] + "p" : "N/A"), | |
stream_dimension: stream.dimension, | |
stream_3d: (stream.stereo3d && stream.stereo3d == 1 ? " 3D" : ""), | |
stream_type: (function(stream){ | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
if (stream.type.indexOf(ytcenter.video.format[i].type) == 0) { | |
return ytcenter.language.getLocale(ytcenter.video.format[i].name); | |
} | |
} | |
return ytcenter.language.getLocale("UNKNOWN"); | |
})(stream) | |
}); | |
} else { | |
btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP_NONE"), { | |
type: (function(){ | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
if (ytcenter.settings.downloadFormat == ytcenter.video.format[i].key) { | |
return ytcenter.language.getLocale(ytcenter.video.format[i].name); | |
} | |
} | |
return ytcenter.language.getLocale("UNKNOWN"); | |
})() | |
}); | |
} | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
var stream = $DownloadButtonStream(); | |
if (stream != null) { | |
var stream_name = { | |
highres: ytcenter.language.getLocale("HIGHRES"), | |
hd1440: ytcenter.language.getLocale("HD1440"), | |
hd1080: ytcenter.language.getLocale("HD1080"), | |
hd720: ytcenter.language.getLocale("HD720"), | |
large: ytcenter.language.getLocale("LARGE"), | |
medium: ytcenter.language.getLocale("MEDIUM"), | |
small: ytcenter.language.getLocale("SMALL") | |
}[stream.quality]; | |
btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP"), { | |
stream_name: stream_name, | |
stream_resolution: (stream.dimension ? stream.dimension.split("x")[1] + "p" : "N/A"), | |
stream_dimension: stream.dimension, | |
stream_3d: (stream.stereo3d && stream.stereo3d == 1 ? " 3D" : ""), | |
stream_type: (function(stream){ | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
if (stream.type.indexOf(ytcenter.video.format[i].type) == 0) { | |
return ytcenter.language.getLocale(ytcenter.video.format[i].name); | |
} | |
} | |
return ytcenter.language.getLocale("UNKNOWN"); | |
})(stream) | |
}); | |
} else { | |
btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP_NONE"), { | |
type: (function(){ | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
if (ytcenter.settings.downloadFormat == ytcenter.video.format[i].key) { | |
return ytcenter.language.getLocale(ytcenter.video.format[i].name); | |
} | |
} | |
return ytcenter.language.getLocale("UNKNOWN"); | |
})() | |
}); | |
} | |
}); | |
btn1a.appendChild(btn1); | |
var btn1_text = document.createElement("span"); | |
btn1_text.className = "yt-uix-button-content"; | |
btn1_text.textContent = ytcenter.language.getLocale("BUTTON_DOWNLOAD_TEXT"); | |
ytcenter.language.addLocaleElement(btn1_text, "BUTTON_DOWNLOAD_TEXT", "@textContent"); | |
btn1.appendChild(btn1_text); | |
g.appendChild(btn1a); | |
var btn2 = document.createElement("button"); | |
btn2.className = "end yt-uix-button yt-uix-tooltip" + (!ytcenter.watch7 ? " yt-uix-button-default" : " yt-uix-button-text"); | |
btn2.setAttribute("onclick", ";return false;"); | |
btn2.setAttribute("type", "button"); | |
btn2.setAttribute("role", "button"); | |
btn2.title = ytcenter.language.getLocale("BUTTON_DOWNlOAD2_TOOLTIP"); | |
ytcenter.language.addLocaleElement(btn2, "BUTTON_DOWNlOAD2_TOOLTIP", "title"); | |
var img = document.createElement("img"); | |
img.className = "yt-uix-button-arrow"; | |
img.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
img.setAttribute("alt", ""); | |
img.style.marginLeft = "0px"; | |
img.style.marginRight = "0px"; | |
btn2.appendChild(img); | |
var stream_groups = (function(){ | |
var groups = (function(){ | |
var obj = {}; | |
for (var i = 0; i < ytcenter.video.format.length; i++) { | |
obj[ytcenter.video.format[i].type] = { | |
label: ytcenter.video.format[i].name, | |
key: ytcenter.video.format[i].key, | |
help: ytcenter.video.format[i].help | |
}; | |
} | |
return obj; | |
})(); | |
var sorted = {}; | |
for (var i = 0; i < ytcenter.video.streams.length; i++) { | |
if (ytcenter.video.streams[i].type.indexOf("audio/mp4") !== 0 && (ytcenter.video.streams[i].size || ytcenter.video.streams[i].bitrate)) continue; | |
if (ytcenter.video.streams[i].type) { | |
var f = ytcenter.video.streams[i].type.split(";")[0]; | |
if (groups.hasOwnProperty(f)) { | |
if (!sorted[groups[f].label]) sorted[groups[f].label] = {streams: [], key: groups[f].key, help: groups[f].help}; | |
sorted[groups[f].label].streams.push(ytcenter.video.streams[i]); | |
} else { | |
if (!sorted['UNKNOWN']) sorted['UNKNOWN'] = {streams: [], key: "unknown"}; | |
sorted['UNKNOWN'].streams.push(ytcenter.video.streams[i]); | |
} | |
} else { | |
if (!sorted['UNKNOWN']) sorted['UNKNOWN'] = {streams: [], key: "unknown"}; | |
sorted['UNKNOWN'].streams.push(ytcenter.video.streams[i]); | |
} | |
} | |
return sorted; | |
})(); | |
var menu = document.createElement("ul"); | |
menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid" + (ytcenter.settings.show3DInDownloadMenu ? "" : " ytcenter-menu-3d-hide"); | |
menu.setAttribute("role", "menu"); | |
menu.setAttribute("aria-haspopup", "true"); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.show3DInDownloadMenu) { | |
ytcenter.utils.removeClass(menu, "ytcenter-menu-3d-hide"); | |
} else { | |
ytcenter.utils.addClass(menu, "ytcenter-menu-3d-hide"); | |
} | |
}); | |
for (var key in stream_groups) { | |
if (stream_groups.hasOwnProperty(key)) { | |
var title = document.createElement("li"); | |
title.setAttribute("role", "menuitem"); | |
title.style.color = "#666"; | |
title.style.fontSize = "0.9166em"; | |
title.style.paddingLeft = "9px"; | |
if (key !== "UNKNOWN") { | |
var __t = document.createTextNode(ytcenter.language.getLocale(key)); | |
title.appendChild(__t); | |
ytcenter.language.addLocaleElement(__t, key, "@textContent"); | |
title.className = "ytcenter-downloadmenu-" + stream_groups[key].key; | |
if (stream_groups[key].help) { | |
var help = document.createElement("a"); | |
help.setAttribute("href", stream_groups[key].help); | |
help.setAttribute("target", "_blank"); | |
help.setAttribute("style", "vertical-align: super; font-size: 10px"); | |
help.appendChild(document.createTextNode('?')); | |
var replace = { | |
option: { | |
toString: function() { return ytcenter.language.getLocale(key); } | |
} | |
}; | |
help.setAttribute("title", ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("SETTINGS_HELP_ABOUT"), replace)); | |
ytcenter.language.addLocaleElement(help, "SETTINGS_HELP_ABOUT", "title", replace); | |
title.appendChild(help); | |
} | |
} else { | |
title.className = "ytcenter-downloadmenu-unknown"; | |
title.textContent = ytcenter.language.getLocale("UNKNOWN"); | |
ytcenter.language.addLocaleElement(title, "UNKNOWN", "@textContent"); | |
} | |
//stream_groups[key] = stream_groups[key].streams; // Just lazy... | |
menu.appendChild(title); | |
for (var i = 0; i < stream_groups[key].streams.length; i++) { | |
var is3D = (stream_groups[key].streams[i].stereo3d && stream_groups[key].streams[i].stereo3d == 1 ? true : false); | |
var item = document.createElement("a"); | |
if (!stream_groups[key].streams[i].url) { | |
item.style.color = "#A7A7A7"; | |
item.style.display = "block"; | |
item.style.margin = "0"; | |
item.style.padding = "6px 20px"; | |
item.style.textDecoration = "none"; | |
item.style.whiteSpace = "nowrap"; | |
item.style.wordWrap = "normal"; | |
} else { | |
item.className = "yt-uix-button-menu-item"; | |
item.setAttribute("target", "_blank"); | |
item.setAttribute("download", ytcenter.video.getFilename(stream_groups[key].streams[i]) + ytcenter.video.getFilenameExtension(stream_groups[key].streams[i])); | |
item.href = ytcenter.video.downloadLink(stream_groups[key].streams[i]); | |
var downloadStreamListener = (function(_stream){ | |
return function(e){ | |
if (!ytcenter.settings.downloadAsLinks) { | |
ytcenter.video.download(_stream.itag); | |
e.preventDefault(); | |
} | |
}; | |
})(stream_groups[key].streams[i]); | |
ytcenter.utils.addEventListener(item, "click", downloadStreamListener, false); | |
ytcenter.events.addEvent("ui-refresh", (function(__stream, item, _downloadStreamListener){ | |
return function(){ | |
item.href = ytcenter.video.downloadLink(__stream); | |
item.setAttribute("download", ytcenter.video.getFilename(__stream) + ytcenter.video.getFilenameExtension(__stream)); | |
}; | |
})(stream_groups[key].streams[i], item, downloadStreamListener)); | |
} | |
var stream_name = { | |
highres: ytcenter.language.getLocale("HIGHRES"), | |
hd1440: ytcenter.language.getLocale("HD1440"), | |
hd1080: ytcenter.language.getLocale("HD1080"), | |
hd720: ytcenter.language.getLocale("HD720"), | |
large: ytcenter.language.getLocale("LARGE"), | |
medium: ytcenter.language.getLocale("MEDIUM"), | |
small: ytcenter.language.getLocale("SMALL") | |
}[stream_groups[key].streams[i].quality]; | |
var _t = document.createElement("table"), _tb = document.createElement("tbody"), _tr = document.createElement("tr"), _td = document.createElement("td"), _td2 = document.createElement("td"); | |
_t.style.width = "100%"; | |
_t.style.border = "0"; | |
_t.style.margin = "0"; | |
_t.style.padding = "0"; | |
if (stream_groups[key].streams[i].bitrate) { | |
_td.textContent = Math.round(parseInt(stream_groups[key].streams[i].bitrate)/1000) + " Kbps"; | |
} else { | |
_td.textContent = stream_name + ", " + (stream_groups[key].streams[i].dimension ? stream_groups[key].streams[i].dimension.split("x")[1] : "") + "p (" + (stream_groups[key].streams[i].dimension ? stream_groups[key].streams[i].dimension : "") + ")"; | |
_td2.textContent = (is3D ? " 3D" : ""); | |
} | |
_tr.appendChild(_td); | |
_tr.appendChild(_td2); | |
_tb.appendChild(_tr); | |
_t.appendChild(_tb); | |
item.appendChild(_t); | |
ytcenter.events.addEvent("ui-refresh", (function(stream, _is3D, _td, _td2){ | |
return function(){ | |
var stream_name = { | |
highres: ytcenter.language.getLocale("HIGHRES"), | |
hd1440: ytcenter.language.getLocale("HD1440"), | |
hd1080: ytcenter.language.getLocale("HD1080"), | |
hd720: ytcenter.language.getLocale("HD720"), | |
large: ytcenter.language.getLocale("LARGE"), | |
medium: ytcenter.language.getLocale("MEDIUM"), | |
small: ytcenter.language.getLocale("SMALL") | |
}[stream.quality]; | |
if (stream.bitrate) { | |
_td.textContent = Math.round(parseInt(stream.bitrate)/1000) + " Kbps"; | |
} else { | |
_td.textContent = stream_name + ", " + (stream.dimension ? stream.dimension.split("x")[1] : "") + "p (" + (stream.dimension ? stream.dimension : "") + ")"; | |
_td2.textContent = (_is3D ? " 3D" : ""); | |
} | |
}; | |
})(stream_groups[key].streams[i], is3D, _td, _td2)); | |
var li = document.createElement("li"); | |
li.className = "ytcenter-downloadmenu-" + (stream_groups[key].key === "UNKNOWN" ? "unknown" : stream_groups[key].key) + (is3D ? " ytcenter-menu-item-3d" : ""); | |
li.setAttribute("role", "menuitem"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
} | |
} | |
} | |
var mp3title = document.createElement("li"); | |
mp3title.className = (ytcenter.settings.mp3Services == '' ? "hid" : ""); | |
if (ytcenter.settings.mp3Services === '') { | |
mp3title.style.display = "none"; | |
} | |
mp3title.style.color = "#666"; | |
mp3title.style.fontSize = "0.9166em"; | |
mp3title.style.paddingLeft = "9px"; | |
mp3title.textContent = ytcenter.language.getLocale("BUTTON_DOWNLOAD_MENU_MP3SERVICES"); | |
ytcenter.language.addLocaleElement(mp3title, "BUTTON_DOWNLOAD_MENU_MP3SERVICES", "@textContent"); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
if (ytcenter.settings.mp3Services === '') { | |
ytcenter.utils.addClass(mp3title, 'hid'); | |
mp3title.style.display = "none"; | |
} else { | |
ytcenter.utils.removeClass(mp3title, 'hid'); | |
mp3title.style.display = ""; | |
} | |
}); | |
menu.appendChild(mp3title); | |
var hasMP3Service = function(value){ | |
var a = ytcenter.settings.mp3Services.split("&"); | |
for (var i = 0; i < a.length; i++) { | |
if (decodeURIComponent(a[i]) === value) { | |
return true; | |
} | |
} | |
return false; | |
}; | |
var removeNonExistentMP3Services = function(){ | |
var newArr = []; | |
var a = ytcenter.settings.mp3Services.split("&"); | |
for (var i = 0; i < a.length; i++) { | |
for (var j = 0; j < ytcenter.mp3services.length; j++) { | |
if (ytcenter.mp3services[j].value === decodeURIComponent(a[i])) { | |
newArr.push(a[i]); | |
break; | |
} | |
} | |
} | |
ytcenter.settings.mp3Services = newArr.join("&"); | |
}; | |
removeNonExistentMP3Services(); | |
for (var i = 0; i < ytcenter.mp3services.length; i++) { | |
var li = document.createElement("li"); | |
var item = document.createElement("a"); | |
item.className = "yt-uix-button-menu-item"; | |
li.setAttribute("role", "menuitem"); | |
li.className = "ytcenter-downloadmenu-MP3" + (hasMP3Service(ytcenter.mp3services[i].value) ? "" : " hid"); | |
if (!hasMP3Service(ytcenter.mp3services[i].value)) { | |
li.style.display = "none"; | |
} | |
item.setAttribute("href", ytcenter.utils.replaceTextAsString(ytcenter.mp3services[i].value, { | |
title: ytcenter.video.title, | |
videoid: ytcenter.video.id, | |
author: ytcenter.video.author, | |
url: loc.href | |
})); | |
item.setAttribute("target", "_blank"); | |
var mp3RedirectListener = (function(mp3){ | |
return function(e){ | |
if (!ytcenter.settings.downloadAsLinks) { | |
ytcenter.redirect(mp3.value, true); | |
e.preventDefault(); | |
return false; | |
} | |
}; | |
})(ytcenter.mp3services[i]); | |
ytcenter.utils.addEventListener(item, "click", mp3RedirectListener, false); | |
ytcenter.events.addEvent("ui-refresh", (function(mp3, li){ | |
return function(){ | |
var a = ytcenter.settings.mp3Services.split("&"); | |
var f = false; | |
for (var i = 0; i < a.length; i++) { | |
if (decodeURIComponent(a[i]) === mp3.value) { | |
f = true; | |
break; | |
} | |
} | |
if (f) { | |
ytcenter.utils.removeClass(li, 'hid'); | |
li.style.display = ""; | |
} else { | |
ytcenter.utils.addClass(li, 'hid'); | |
li.style.display = "none"; | |
} | |
}; | |
})(ytcenter.mp3services[i], li)); | |
item.textContent = ytcenter.language.getLocale(ytcenter.mp3services[i].label); | |
ytcenter.language.addLocaleElement(item, ytcenter.mp3services[i].label, "@textContent"); | |
li.appendChild(item); | |
menu.appendChild(li); | |
} | |
btn2.appendChild(menu); | |
g.appendChild(btn2); | |
ytcenter.placementsystem.addElement("ytcenter", "downloadgroup", g); | |
} | |
function $CreateSettingsUI() { | |
var appbar = document.getElementById("appbar-settings-menu"), | |
appSecondaryContainer = document.getElementById("appbar-secondary-container"), | |
liSettings = document.createElement("li"), | |
spanText = document.createElement("span"), | |
textIconContainer = document.createElement("span"), | |
textIcon = document.createElement("img"), | |
text = null; | |
if (ytcenter.feather) { | |
var wrapper = document.getElementById("us"), | |
aLink = document.createElement("a"), | |
gearicon = document.createElement("img"); | |
gearicon.src = ytcenter.icon.gear; | |
gearicon.setAttribute("alt", ""); | |
aLink.appendChild(gearicon); | |
aLink.className = "ml"; | |
aLink.setAttribute("href", "javascript:void(0);"); | |
ytcenter.utils.addEventListener(aLink, "click", function(e){ | |
if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); | |
ytcenter.settingsPanelDialog.setVisibility(true); | |
e && e.preventDefault && e.preventDefault(); | |
return false; | |
}, false); | |
aLink.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); | |
ytcenter.language.addLocaleElement(aLink, "BUTTON_SETTINGS_TITLE", "title"); | |
wrapper.appendChild(aLink); | |
} else if (appbar) { | |
liSettings.setAttribute("id", "ytcenter-settings-toggler"); | |
liSettings.setAttribute("role", "menuitem"); | |
liSettings.className = "yt-uix-button-menu-new-section-separator"; | |
spanText.className = "yt-uix-button-menu-item upload-menu-item"; | |
ytcenter.utils.addEventListener(spanText, "click", function(){ | |
if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); | |
ytcenter.settingsPanelDialog.setVisibility(true); | |
}, false); | |
textIconContainer.className = "yt-valign icon-container"; | |
textIcon.className = "upload-menu-account-settings-icon yt-valign-container"; | |
textIcon.setAttribute("src", "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"); | |
textIconContainer.appendChild(textIcon); | |
text = document.createTextNode(ytcenter.language.getLocale("BUTTON_SETTINGS_LABEL")); | |
ytcenter.language.addLocaleElement(text, "BUTTON_SETTINGS_LABEL", "@textContent"); | |
spanText.appendChild(textIconContainer); | |
spanText.appendChild(text); | |
liSettings.appendChild(spanText); | |
appbar.appendChild(liSettings); | |
} else if (appSecondaryContainer) { | |
var btn = document.createElement("button"), | |
iconWrapper = document.createElement("span"), | |
icon = document.createElement("img"); | |
btn.className = "appbar-action-button flip yt-uix-button yt-uix-button-default yt-uix-button-size-default yt-uix-button-has-icon yt-uix-button-empty yt-uix-tooltip"; | |
btn.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); | |
ytcenter.language.addLocaleElement(btn, "BUTTON_SETTINGS_TITLE", "title"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
ytcenter.utils.addEventListener(btn, "click", function(){ | |
if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); | |
ytcenter.settingsPanelDialog.setVisibility(true); | |
}, false); | |
iconWrapper.className = "yt-uix-button-icon-wrapper"; | |
icon.className = "yt-uix-button-icon yt-uix-button-icon-appbar-settings"; | |
icon.src = "https://s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"; | |
icon.setAttribute("alt", ""); | |
icon.setAttribute("title", ""); | |
iconWrapper.appendChild(icon); | |
btn.appendChild(iconWrapper); | |
appSecondaryContainer.appendChild(btn); | |
} else { | |
var btn = document.createElement("button"); | |
btn.id = "masthead-user-button"; | |
if (document.getElementById("masthead-gaia-photo-expander")) { | |
btn.style.marginTop = "3px"; | |
} else if (document.getElementById("masthead-user-expander")) { | |
btn.style.verticalAlign = "middle"; | |
} | |
btn.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); | |
ytcenter.language.addLocaleElement(btn, "BUTTON_SETTINGS_TITLE", "title"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.className = "yt-uix-tooltip-reverse yt-uix-button " + (ytcenter.watch7 ? "yt-uix-button-text" : "yt-uix-button-text") + " yt-uix-tooltip"; | |
var btnt = document.createElement("span"); | |
btnt.className = "yt-uix-button-icon-wrapper"; | |
btnt.style.margin = "0"; | |
var gearicon = document.createElement("img"); | |
gearicon.src = ytcenter.icon.gear; | |
gearicon.setAttribute("alt", ""); | |
var ytvt = document.createElement("span"); | |
ytvt.className = "yt-valign-trick"; | |
btnt.appendChild(gearicon); | |
btnt.appendChild(ytvt); | |
btn.appendChild(btnt); | |
var ytuixbc = document.createElement("span"); | |
ytuixbc.className = "yt-uix-button-content"; | |
ytuixbc.textContent = " "; | |
btn.appendChild(ytuixbc); | |
ytcenter.utils.addEventListener(btn, "click", function(){ | |
if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); | |
ytcenter.settingsPanelDialog.setVisibility(true); | |
}, false); | |
if (document.getElementById("masthead-user")) { | |
document.getElementById("masthead-user").appendChild(btn); | |
} else if (document.getElementById("yt-masthead-user")) { | |
document.getElementById("yt-masthead-user").appendChild(btn); | |
} else if (document.getElementById("yt-masthead-signin")) { | |
btn.style.margin = "0 10px"; | |
document.getElementById("yt-masthead-signin").appendChild(btn); | |
} else { | |
con.error("Settings UI - Couldn't add settings button"); | |
} | |
} | |
} | |
function $CloneArray(arr) { | |
var copy = []; | |
for (var i = 0; i < arr.length; i++) { | |
copy[i] = arr[i]; | |
} | |
return copy; | |
} | |
function $Clone(obj) { | |
var copy; | |
if (null == obj || typeof obj != "object") { | |
return obj; | |
} | |
if (obj instanceof Date) { | |
copy = new Date(); | |
copy.setTime(obj.getTime()); | |
return copy; | |
} | |
if (obj instanceof Array) { | |
copy = []; | |
for (var i = 0; i < obj.length; i++) { | |
copy[i] = $Clone(obj[i]); | |
} | |
return copy; | |
} | |
if (obj instanceof Object) { | |
copy = {}; | |
for (var key in obj) { | |
if (obj.hasOwnProperty(key)) { | |
copy[key] = $Clone(obj[key]); | |
} | |
} | |
return copy; | |
} | |
return null; | |
} | |
function $ArrayIndexOf(arr, obj) { | |
for (var i = 0; i < arr.length; i++) { | |
if (arr[i] === obj) return i; | |
} | |
return -1; | |
} | |
function $SlideRange(elm, handle, min, max, defaultValue) { | |
function mousemove(e){ | |
if (range.mouse.down) { | |
e.preventDefault(); | |
if (e && e.type.indexOf("touch") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { | |
e = e.changedTouches[0]; | |
} | |
var pos = e.clientX - $AbsoluteOffset(range.elm)[0] - range.handle.offsetWidth/2; | |
var max = range.elm.clientWidth - range.handle.offsetWidth; | |
if (pos > max) { | |
pos = max; | |
} else if (pos < 0) { | |
pos = 0; | |
} | |
range.handle.style.left = pos + "px"; | |
for (var i = 0; i < range.listeners.length; i++) { | |
if (range.listeners[i].e === 'valuechange') { | |
var max = range.elm.clientWidth - range.handle.offsetWidth; | |
var a = range.max - range.min; | |
range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); | |
} | |
} | |
} | |
} | |
function mousedownListener(e){ | |
range.mouse.down = true; | |
throttleFunc = ytcenter.utils.throttle(mousemove, 50); | |
ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false); | |
ytcenter.utils.addEventListener(document, "touchmove", throttleFunc, false); | |
e.preventDefault(); | |
} | |
function mouseupListener(e){ | |
if (range.mouse.down) { | |
range.mouse.down = false; | |
e.stopPropagation(); | |
for (var i = 0; i < range.listeners.length; i++) { | |
if (range.listeners[i].e === 'change') { | |
var max = range.elm.clientWidth - range.handle.offsetWidth; | |
var a = range.max - range.min; | |
range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); | |
} | |
} | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "mousemove", throttleFunc, false); | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "touchmove", throttleFunc, false); | |
e.preventDefault(); | |
} | |
} | |
function clickListener(e) { | |
var a; | |
var pos = e.clientX - $AbsoluteOffset(range.elm)[0] - range.handle.offsetWidth/2; | |
var max = range.elm.clientWidth - range.handle.offsetWidth; | |
if (pos > max) { | |
pos = max; | |
} else if (pos < 0) { | |
pos = 0; | |
} | |
range.handle.style.left = pos + "px"; | |
for (var i = 0; i < range.listeners.length; i++) { | |
if (range.listeners[i].e === 'valuechange') { | |
max = range.elm.clientWidth - range.handle.offsetWidth; | |
a = range.max - range.min; | |
range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); | |
} else if (range.listeners[i].e === 'change') { | |
max = range.elm.clientWidth - range.handle.offsetWidth; | |
a = range.max - range.min; | |
range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); | |
} | |
} | |
e.preventDefault(); | |
} | |
var range = { | |
elm: elm, | |
handle: handle, | |
min: (min ? min : 0), | |
max: (max ? max : 100), | |
defaultValue: (defaultValue ? defaultValue : min), | |
mouse: { | |
down: false | |
}, | |
listeners: [], | |
width: 240, | |
height: 15 | |
}, throttleFunc = null; | |
range.elm.style.marginTop = "-4px"; | |
range.elm.style.width = range.width + "px"; | |
range.elm.style.height = range.height + "px"; | |
range.handle.style.width = range.height + "px"; | |
range.handle.style.height = range.height + "px"; | |
var returnKit = { | |
addEventListener: (function(range){ | |
return function(event, callback){ | |
range.listeners.push({ | |
e: event, | |
c: callback | |
}); | |
}; | |
})(range), | |
getValue: (function(range){ | |
return function(){ | |
var max = parseInt(range.elm.style.width) - (range.height + 2); | |
var a = range.max - range.min; | |
return parseFloat(range.handle.style.left)/max*a+range.min || range.defaultValue; | |
}; | |
})(range), | |
setValue: (function(range){ | |
return function(val){ | |
var max = parseInt(range.elm.style.width) - (range.height + 2); | |
var pos = (val - range.min)/(range.max - range.min)*max; | |
if (pos > max) { | |
pos = max; | |
} else if (pos < 0) { | |
pos = 0; | |
} | |
range.handle.style.left = pos + "px"; | |
if (val == 0) { | |
return 0; | |
} else { | |
return returnKit.getValue(); | |
} | |
}; | |
})(range) | |
}; | |
returnKit.setValue(range.defaultValue); | |
ytcenter.utils.addEventListener(elm, "click", clickListener, false); | |
/* Mouse */ | |
ytcenter.utils.addEventListener(elm, "mousedown", mousedownListener, false); | |
ytcenter.utils.addEventListener(document, "mouseup", mouseupListener, false); | |
/* Touch */ | |
ytcenter.utils.addEventListener(elm, "touchstart", mousedownListener, false); | |
ytcenter.utils.addEventListener(document, "touchend", mouseupListener, false); | |
return returnKit; | |
} | |
function $AbsoluteOffset(elm) { | |
var pos = [elm.offsetLeft || 0, elm.offsetTop || 0]; | |
if (elm.offsetParent) { | |
var ao = $AbsoluteOffset(elm.offsetParent); | |
pos[0] += ao[0]; | |
pos[1] += ao[1]; | |
} | |
return pos; | |
} | |
function addPropertyWrapper(parent, property, wrapperFunc, callback) { | |
function waitObject(parent, token) { | |
var value; | |
var loaded = false; | |
// TODO research if it's possible to add listeners to an object instead of using setter and getter. | |
defineLockedProperty(parent, token, function(aValue){ | |
value = aValue; // Always set the value as it's supposed to act like a normal property. | |
if (!loaded) { | |
loaded = true; | |
iterate(); // Let's start the iteration again. | |
} | |
}, function(){ | |
return value; | |
}); | |
} | |
function iterate() { | |
var token; | |
// Make sure that at least one item is in the tokens array. | |
while (tokens.length > 1 && (token = tokens.shift())) { | |
// If the next token doesn't exists as a property then attach a `getter and setter` and wait for it to be written to. | |
if (!parent[token]) { | |
con.log("[Property Wrapper] Property doesn't exists in parent, attaching trigger using `getter and setter`."); | |
waitObject(parent, token); | |
tokens = [token].concat(tokens); // We attach the token at the start of the array because we removed it in while. | |
return; // I will return one day... | |
} | |
parent = parent[token]; | |
} | |
// We got to the end and we will then add the wrapper. | |
addWrapper(); | |
} | |
function addWrapper() { | |
var func = parent[tokens[0]]; | |
con.log("[Property Wrapper] Wrapping `" + tokens[0] + "` function in a wrapper."); | |
defineLockedProperty(parent, tokens[tokens.length - 1], function(value){ | |
func = value; | |
}, function(){ | |
return function(){ | |
if (typeof func === "function") { | |
var args = Array.prototype.slice.call(arguments, 0); | |
var value = func.apply(this, args); | |
wrapperFunc.apply(this, [value].concat(args)); | |
} else { | |
con.warn("[Property Wrapper] Wrapped function is not a function!", func); | |
} | |
return value; | |
}; | |
}); | |
callback(); | |
} | |
con.log("[Property Wrapper] Wrapping the function " + tokens + " into a function wrapper."); | |
// Creating the tokens from property | |
var tokens = property.split("."); | |
// Let's start our iteration | |
iterate(); | |
} | |
/* END UTILS */ | |
/* Classes (what) */ | |
function defineLockedProperty(obj, key, setter, getter) { | |
if (typeof obj !== "object") obj = {}; | |
if (ytcenter.utils.ie || (typeof Object.defineProperty === "function" && !obj.__defineGetter__)) { | |
Object.defineProperty(obj, key, { | |
get: getter, | |
set: setter | |
}); | |
return obj; | |
} else { | |
obj.__defineGetter__(key, getter); | |
obj.__defineSetter__(key, setter); | |
return obj; | |
} | |
} | |
function freeze(parent, freezeObject, predefinedObject) { | |
function wait(_parent, _freezeObject) { | |
var args = _freezeObject.split("."); | |
var _object = undefined; | |
defineLockedProperty(_parent, args[0], function(val){ | |
args.splice(0, 1); | |
freeze(val, args.join(".")); | |
_object = val; | |
}, function(){ | |
return _object; | |
}); | |
} | |
var args = freezeObject.split("."); | |
var at = parent; | |
for (var i = 0, len = args.length - 1; i < len; i++) { | |
if (typeof at[args[i]] === "object") { | |
at = at[args[i]]; | |
} else { | |
args.splice(0, i); | |
wait(at, args.join(".")); | |
return; | |
} | |
} | |
var defObject = predefinedObject; | |
var frozen = typeof predefinedObject !== "undefined"; | |
if (typeof at[args[args.length - 1]] !== "undefined") { | |
defObject = at[args[args.length - 1]]; | |
frozen = true; | |
} | |
defineLockedProperty(at, args[args.length - 1], function(val){ | |
if (!frozen) { | |
frozen = true; | |
defObject = val; | |
} | |
}, function(){ | |
return defObject; | |
}); | |
} | |
var console_debug = devbuild; // Disable this to stop YouTube Center Developer Build from writing in the console log. | |
var _console = []; | |
var uw = null, | |
loc = null, | |
con = null, | |
ytcenter = {}, | |
yt = {}; | |
uw = _unsafeWindow || (function(){ | |
var a; | |
try { | |
a = unsafeWindow === window ? false : unsafeWindow; | |
} catch (e) { | |
} finally { | |
return a || (function(){ | |
try { | |
var e = document.createElement('p'); | |
e.setAttribute('onclick', 'return window;'); | |
return e.onclick(); | |
} catch (e) { | |
return window; | |
} | |
}()); | |
} | |
})(); | |
if (uw && typeof uw.ytcenter !== "undefined") { | |
return; | |
} | |
ytcenter.unsafe = {}; | |
uw.ytcenter = ytcenter.unsafe; | |
ytcenter.ltr = true; | |
ytcenter.utils = {}; | |
ytcenter.utils.createCustomEvent = function(type, detail) { | |
try { | |
var e = document.createEvent('CustomEvent'); | |
if (detail) { | |
e.initCustomEvent(type, true, true, detail); | |
} else { | |
e.initCustomEvent(type, true, true); | |
} | |
return e; | |
} catch (e) { | |
var e = new CustomEvent(type); | |
if (detail) { | |
e.detail = detail; | |
} | |
return e; | |
} | |
}; | |
ytcenter.utils.ie = (function(){ | |
for (var v = 3, el = document.createElement('b'), all = el.all || []; el.innerHTML = '<!--[if gt IE ' + (++v) + ']><i><![endif]-->', all[0];); | |
return v > 4 ? v : !!document.documentMode; | |
}()); | |
function getAPIKey() { | |
return ytcenter.settings.google_apikey || "AIzaSyCO5gfGpEiqmc8XTknN9RyC3TCJz1-XyAI"; | |
} | |
/** | |
* UAParser.js v0.7.3 | |
* Lightweight JavaScript-based User-Agent string parser | |
* https://github.com/faisalman/ua-parser-js | |
* | |
* Copyright © 2012-2014 Faisal Salman <fyzlman@gmail.com> | |
* Dual licensed under GPLv2 & MIT | |
*/ | |
(function(e,t){"use strict";var n="0.7.3",r="",i="?",s="function",o="undefined",u="object",a="major",f="model",l="name",c="type",h="vendor",p="version",d="architecture",v="console",m="mobile",g="tablet",y="smarttv",b="wearable",w="embedded";var E={extend:function(e,t){for(var n in t){if("browser cpu device engine os".indexOf(n)!==-1&&t[n].length%2===0){e[n]=t[n].concat(e[n])}}return e},has:function(e,t){if(typeof e==="string"){return t.toLowerCase().indexOf(e.toLowerCase())!==-1}},lowerize:function(e){return e.toLowerCase()}};var S={rgx:function(){var e,n=0,r,i,a,f,l,c,h=arguments;while(n<h.length&&!l){var p=h[n],d=h[n+1];if(typeof e===o){e={};for(a in d){f=d[a];if(typeof f===u){e[f[0]]=t}else{e[f]=t}}}r=i=0;while(r<p.length&&!l){l=p[r++].exec(this.getUA());if(!!l){for(a=0;a<d.length;a++){c=l[++i];f=d[a];if(typeof f===u&&f.length>0){if(f.length==2){if(typeof f[1]==s){e[f[0]]=f[1].call(this,c)}else{e[f[0]]=f[1]}}else if(f.length==3){if(typeof f[1]===s&&!(f[1].exec&&f[1].test)){e[f[0]]=c?f[1].call(this,c,f[2]):t}else{e[f[0]]=c?c.replace(f[1],f[2]):t}}else if(f.length==4){e[f[0]]=c?f[3].call(this,c.replace(f[1],f[2])):t}}else{e[f]=c?c:t}}}}n+=2}return e},str:function(e,n){for(var r in n){if(typeof n[r]===u&&n[r].length>0){for(var s=0;s<n[r].length;s++){if(E.has(n[r][s],e)){return r===i?t:r}}}else if(E.has(n[r],e)){return r===i?t:r}}return e}};var x={browser:{oldsafari:{major:{1:["/8","/1","/3"],2:"/4","?":"/"},version:{"1.0":"/8",1.2:"/1",1.3:"/3","2.0":"/412","2.0.2":"/416","2.0.3":"/417","2.0.4":"/419","?":"/"}}},device:{amazon:{model:{"Fire Phone":["SD","KF"]}},sprint:{model:{"Evo Shift 4G":"7373KT"},vendor:{HTC:"APA",Sprint:"Sprint"}}},os:{windows:{version:{ME:"4.90","NT 3.11":"NT3.51","NT 4.0":"NT4.0",2e3:"NT 5.0",XP:["NT 5.1","NT 5.2"],Vista:"NT 6.0",7:"NT 6.1",8:"NT 6.2",8.1:"NT 6.3",10:"NT 6.4",RT:"ARM"}}}};var T={browser:[[/(opera\smini)\/((\d+)?[\w\.-]+)/i,/(opera\s[mobiletab]+).+version\/((\d+)?[\w\.-]+)/i,/(opera).+version\/((\d+)?[\w\.]+)/i,/(opera)[\/\s]+((\d+)?[\w\.]+)/i],[l,p,a],[/\s(opr)\/((\d+)?[\w\.]+)/i],[[l,"Opera"],p,a],[/(kindle)\/((\d+)?[\w\.]+)/i,/(lunascape|maxthon|netfront|jasmine|blazer)[\/\s]?((\d+)?[\w\.]+)*/i,/(avant\s|iemobile|slim|baidu)(?:browser)?[\/\s]?((\d+)?[\w\.]*)/i,/(?:ms|\()(ie)\s((\d+)?[\w\.]+)/i,/(rekonq)((?:\/)[\w\.]+)*/i,/(chromium|flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron)\/((\d+)?[\w\.-]+)/i],[l,p,a],[/(trident).+rv[:\s]((\d+)?[\w\.]+).+like\sgecko/i],[[l,"IE"],p,a],[/(yabrowser)\/((\d+)?[\w\.]+)/i],[[l,"Yandex"],p,a],[/(comodo_dragon)\/((\d+)?[\w\.]+)/i],[[l,/_/g," "],p,a],[/(chrome|omniweb|arora|[tizenoka]{5}\s?browser)\/v?((\d+)?[\w\.]+)/i,/(uc\s?browser|qqbrowser)[\/\s]?((\d+)?[\w\.]+)/i],[l,p,a],[/(dolfin)\/((\d+)?[\w\.]+)/i],[[l,"Dolphin"],p,a],[/((?:android.+)crmo|crios)\/((\d+)?[\w\.]+)/i],[[l,"Chrome"],p,a],[/version\/((\d+)?[\w\.]+).+?mobile\/\w+\s(safari)/i],[p,a,[l,"Mobile Safari"]],[/version\/((\d+)?[\w\.]+).+?(mobile\s?safari|safari)/i],[p,a,l],[/webkit.+?(mobile\s?safari|safari)((\/[\w\.]+))/i],[l,[a,S.str,x.browser.oldsafari.major],[p,S.str,x.browser.oldsafari.version]],[/(konqueror)\/((\d+)?[\w\.]+)/i,/(webkit|khtml)\/((\d+)?[\w\.]+)/i],[l,p,a],[/(navigator|netscape)\/((\d+)?[\w\.-]+)/i],[[l,"Netscape"],p,a],[/(swiftfox)/i,/(icedragon|iceweasel|camino|chimera|fennec|maemo\sbrowser|minimo|conkeror)[\/\s]?((\d+)?[\w\.\+]+)/i,/(firefox|seamonkey|k-meleon|icecat|iceape|firebird|phoenix)\/((\d+)?[\w\.-]+)/i,/(mozilla)\/((\d+)?[\w\.]+).+rv\:.+gecko\/\d+/i,/(polaris|lynx|dillo|icab|doris|amaya|w3m|netsurf)[\/\s]?((\d+)?[\w\.]+)/i,/(links)\s\(((\d+)?[\w\.]+)/i,/(gobrowser)\/?((\d+)?[\w\.]+)*/i,/(ice\s?browser)\/v?((\d+)?[\w\._]+)/i,/(mosaic)[\/\s]((\d+)?[\w\.]+)/i],[l,p,a]],cpu:[[/(?:(amd|x(?:(?:86|64)[_-])?|wow|win)64)[;\)]/i],[[d,"amd64"]],[/(ia32(?=;))/i],[[d,E.lowerize]],[/((?:i[346]|x)86)[;\)]/i],[[d,"ia32"]],[/windows\s(ce|mobile);\sppc;/i],[[d,"arm"]],[/((?:ppc|powerpc)(?:64)?)(?:\smac|;|\))/i],[[d,/ower/,"",E.lowerize]],[/(sun4\w)[;\)]/i],[[d,"sparc"]],[/((?:avr32|ia64(?=;))|68k(?=\))|arm(?:64|(?=v\d+;))|(?=atmel\s)avr|(?:irix|mips|sparc)(?:64)?(?=;)|pa-risc)/i],[[d,E.lowerize]]],device:[[/\((ipad|playbook);[\w\s\);-]+(rim|apple)/i],[f,h,[c,g]],[/applecoremedia\/[\w\.]+ \((ipad)/],[f,[h,"Apple"],[c,g]],[/(apple\s{0,1}tv)/i],[[f,"Apple TV"],[h,"Apple"]],[/(archos)\s(gamepad2?)/i,/(hp).+(touchpad)/i,/(kindle)\/([\w\.]+)/i,/\s(nook)[\w\s]+build\/(\w+)/i,/(dell)\s(strea[kpr\s\d]*[\dko])/i],[h,f,[c,g]],[/(kf[A-z]+)\sbuild\/[\w\.]+.*silk\//i],[f,[h,"Amazon"],[c,g]],[/(sd|kf)[0349hijorstuw]+\sbuild\/[\w\.]+.*silk\//i],[[f,S.str,x.device.amazon.model],[h,"Amazon"],[c,m]],[/\((ip[honed|\s\w*]+);.+(apple)/i],[f,h,[c,m]],[/\((ip[honed|\s\w*]+);/i],[f,[h,"Apple"],[c,m]],[/(blackberry)[\s-]?(\w+)/i,/(blackberry|benq|palm(?=\-)|sonyericsson|acer|asus|dell|huawei|meizu|motorola|polytron)[\s_-]?([\w-]+)*/i,/(hp)\s([\w\s]+\w)/i,/(asus)-?(\w+)/i],[h,f,[c,m]],[/\(bb10;\s(\w+)/i],[f,[h,"BlackBerry"],[c,m]],[/android.+(transfo[prime\s]{4,10}\s\w+|eeepc|slider\s\w+|nexus 7)/i],[f,[h,"Asus"],[c,g]],[/(sony)\s(tablet\s[ps])/i],[h,f,[c,g]],[/\s(ouya)\s/i,/(nintendo)\s([wids3u]+)/i],[h,f,[c,v]],[/android.+;\s(shield)\sbuild/i],[f,[h,"Nvidia"],[c,v]],[/(playstation\s[3portablevi]+)/i],[f,[h,"Sony"],[c,v]],[/(sprint\s(\w+))/i],[[h,S.str,x.device.sprint.vendor],[f,S.str,x.device.sprint.model],[c,m]],[/(lenovo)\s?(S(?:5000|6000)+(?:[-][\w+]))/i],[h,f,[c,g]],[/(htc)[;_\s-]+([\w\s]+(?=\))|\w+)*/i,/(zte)-(\w+)*/i,/(alcatel|geeksphone|huawei|lenovo|nexian|panasonic|(?=;\s)sony)[_\s-]?([\w-]+)*/i],[h,[f,/_/g," "],[c,m]],[/[\s\(;](xbox(?:\sone)?)[\s\);]/i],[f,[h,"Microsoft"],[c,v]],[/(kin\.[onetw]{3})/i],[[f,/\./g," "],[h,"Microsoft"],[c,m]],[/\s((milestone|droid(?:[2-4x]|\s(?:bionic|x2|pro|razr))?(:?\s4g)?))[\w\s]+build\//i,/(mot)[\s-]?(\w+)*/i],[[h,"Motorola"],f,[c,m]],[/android.+\s(mz60\d|xoom[\s2]{0,2})\sbuild\//i],[f,[h,"Motorola"],[c,g]],[/android.+((sch-i[89]0\d|shw-m380s|gt-p\d{4}|gt-n8000|sgh-t8[56]9|nexus 10))/i,/((SM-T\w+))/i],[[h,"Samsung"],f,[c,g]],[/((s[cgp]h-\w+|gt-\w+|galaxy\snexus|sm-n900))/i,/(sam[sung]*)[\s-]*(\w+-?[\w-]*)*/i,/sec-((sgh\w+))/i],[[h,"Samsung"],f,[c,m]],[/(samsung);smarttv/i],[h,f,[c,y]],[/\(dtv[\);].+(aquos)/i],[f,[h,"Sharp"],[c,y]],[/sie-(\w+)*/i],[f,[h,"Siemens"],[c,m]],[/(maemo|nokia).*(n900|lumia\s\d+)/i,/(nokia)[\s_-]?([\w-]+)*/i],[[h,"Nokia"],f,[c,m]],[/android\s3\.[\s\w-;]{10}(a\d{3})/i],[f,[h,"Acer"],[c,g]],[/android\s3\.[\s\w-;]{10}(lg?)-([06cv9]{3,4})/i],[[h,"LG"],f,[c,g]],[/(lg) netcast\.tv/i],[h,f,[c,y]],[/(nexus\s[45])/i,/lg[e;\s\/-]+(\w+)*/i],[f,[h,"LG"],[c,m]],[/android.+(ideatab[a-z0-9\-\s]+)/i],[f,[h,"Lenovo"],[c,g]],[/linux;.+((jolla));/i],[h,f,[c,m]],[/((pebble))app\/[\d\.]+\s/i],[h,f,[c,b]],[/android.+;\s(glass)\s\d/i],[f,[h,"Google"],[c,b]],[/(mobile|tablet);.+rv\:.+gecko\//i],[[c,E.lowerize],h,f]],engine:[[/(presto)\/([\w\.]+)/i,/(webkit|trident|netfront|netsurf|amaya|lynx|w3m)\/([\w\.]+)/i,/(khtml|tasman|links)[\/\s]\(?([\w\.]+)/i,/(icab)[\/\s]([23]\.[\d\.]+)/i],[l,p],[/rv\:([\w\.]+).*(gecko)/i],[p,l]],os:[[/microsoft\s(windows)\s(vista|xp)/i],[l,p],[/(windows)\snt\s6\.2;\s(arm)/i,/(windows\sphone(?:\sos)*|windows\smobile|windows)[\s\/]?([ntce\d\.\s]+\w)/i],[l,[p,S.str,x.os.windows.version]],[/(win(?=3|9|n)|win\s9x\s)([nt\d\.]+)/i],[[l,"Windows"],[p,S.str,x.os.windows.version]],[/\((bb)(10);/i],[[l,"BlackBerry"],p],[/(blackberry)\w*\/?([\w\.]+)*/i,/(tizen)[\/\s]([\w\.]+)/i,/(android|webos|palm\os|qnx|bada|rim\stablet\sos|meego|contiki)[\/\s-]?([\w\.]+)*/i,/linux;.+(sailfish);/i],[l,p],[/(symbian\s?os|symbos|s60(?=;))[\/\s-]?([\w\.]+)*/i],[[l,"Symbian"],p],[/\((series40);/i],[l],[/mozilla.+\(mobile;.+gecko.+firefox/i],[[l,"Firefox OS"],p],[/(nintendo|playstation)\s([wids3portablevu]+)/i,/(mint)[\/\s\(]?(\w+)*/i,/(mageia|vectorlinux)[;\s]/i,/(joli|[kxln]?ubuntu|debian|[open]*suse|gentoo|arch|slackware|fedora|mandriva|centos|pclinuxos|redhat|zenwalk|linpus)[\/\s-]?([\w\.-]+)*/i,/(hurd|linux)\s?([\w\.]+)*/i,/(gnu)\s?([\w\.]+)*/i],[l,p],[/(cros)\s[\w]+\s([\w\.]+\w)/i],[[l,"Chromium OS"],p],[/(sunos)\s?([\w\.]+\d)*/i],[[l,"Solaris"],p],[/\s([frentopc-]{0,4}bsd|dragonfly)\s?([\w\.]+)*/i],[l,p],[/(ip[honead]+)(?:.*os\s*([\w]+)*\slike\smac|;\sopera)/i],[[l,"iOS"],[p,/_/g,"."]],[/(mac\sos\sx)\s?([\w\s\.]+\w)*/i,/(macintosh|mac(?=_powerpc)\s)/i],[[l,"Mac OS"],[p,/_/g,"."]],[/((?:open)?solaris)[\/\s-]?([\w\.]+)*/i,/(haiku)\s(\w+)/i,/(aix)\s((\d)(?=\.|\)|\s)[\w\.]*)*/i,/(plan\s9|minix|beos|os\/2|amigaos|morphos|risc\sos|openvms)/i,/(unix)\s?([\w\.]+)*/i],[l,p]]};var N=function(t,n){if(!(this instanceof N)){return(new N(t,n)).getResult()}var i=t||(e&&e.navigator&&e.navigator.userAgent?e.navigator.userAgent:r);var s=n?E.extend(T,n):T;this.getBrowser=function(){return S.rgx.apply(this,s.browser)};this.getCPU=function(){return S.rgx.apply(this,s.cpu)};this.getDevice=function(){return S.rgx.apply(this,s.device)};this.getEngine=function(){return S.rgx.apply(this,s.engine)};this.getOS=function(){return S.rgx.apply(this,s.os)};this.getResult=function(){return{ua:this.getUA(),browser:this.getBrowser(),engine:this.getEngine(),os:this.getOS(),device:this.getDevice(),cpu:this.getCPU()}};this.getUA=function(){return i};this.setUA=function(e){i=e;return this};this.setUA(i)};N.VERSION=n;N.BROWSER={NAME:l,MAJOR:a,VERSION:p};N.CPU={ARCHITECTURE:d};N.DEVICE={MODEL:f,VENDOR:h,TYPE:c,CONSOLE:v,MOBILE:m,SMARTTV:y,TABLET:g,WEARABLE:b,EMBEDDED:w};N.ENGINE={NAME:l,VERSION:p};N.OS={NAME:l,VERSION:p};ytcenter.UAParser=N})(this) | |
ytcenter.reportIssue = (function(){ | |
function createSettingsCategory() { | |
cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_REPORT"); | |
createInstructions(); | |
createIssueTemplate(); | |
} | |
function createInstructions() { | |
var instructions = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_INSTRUCTIONS"); | |
cat.addSubCategory(instructions); | |
var instructionElement = document.createElement("div"); | |
instructionElement.textContent = "Coming soon."; | |
var option = ytcenter.settingsPanel.createOption( | |
null, | |
"simpleElement", | |
null, | |
{ | |
"element": instructionElement | |
} | |
); | |
instructions.addOption(option); | |
} | |
function createIssueTemplate() { | |
browserDetails = getBrowserDetails(); | |
var template = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_ISSUE_TEMPLATE"); | |
cat.addSubCategory(template); | |
var tempElement = document.createElement("div"); | |
template.addEventListener("click", function(){ | |
generateTemplateElement(tempElement); | |
}); | |
tempElement.addEventListener("copy", function(){ | |
var selection = window.getSelection(); | |
var selectionRange = null; | |
if (selection.getRangeAt && selection.rangeCount) { | |
selectionRange = selection.getRangeAt(0); | |
} | |
var clonedTemplate = tempElement.cloneNode(true); | |
clonedTemplate.className = "ytc-copying"; | |
var titles = clonedTemplate.getElementsByClassName("title"); | |
for (var i = 0, len = titles.length; i < len; i++) { | |
titles[i].textContent = "__" + titles[i].textContent + "__"; | |
} | |
document.body.appendChild(clonedTemplate); | |
selection.selectAllChildren(clonedTemplate); | |
ytcenter.settingsPanel.statusbar.setMessage("Copied", 1500); // TODO Use translated locale | |
setTimeout(function(){ | |
selection.removeAllRanges(); | |
selection.addRange(selectionRange); | |
clonedTemplate.parentNode.removeChild(clonedTemplate); | |
}, 7); | |
}); | |
//generateTemplateElement(tempElement); | |
var option = ytcenter.settingsPanel.createOption( | |
null, | |
"simpleElement", | |
null, | |
{ | |
"element": tempElement | |
} | |
); | |
template.addOption(option); | |
} | |
function generateTemplateElement(tempElement) { | |
tempElement.innerHTML = ""; | |
var list = document.createElement("ul"); | |
for (var i = 0, len = templateList.length; i < len; i++) { | |
var listItem = templateList[i]; | |
var generatedContent = listItem.value(); | |
if (listItem.emptyHide && generatedContent === "") continue; | |
var item = document.createElement("li"); | |
var title = document.createElement("span"); | |
title.className = "title"; | |
title.style.fontWeight = "bold"; | |
title.textContent = listItem.title; | |
item.appendChild(title); | |
var split = document.createElement("span"); | |
split.textContent = ":" + (listItem.addLines ? "" : " "); | |
item.appendChild(split); | |
var content = null; | |
if (listItem.wrapper) { | |
contentGist = contentGist || document.createElement("span"); | |
contentGist.innerHTML = ""; | |
if (!uploadLink) { | |
uploadLink = document.createElement("a"); | |
uploadLink.textContent = "Upload"; | |
uploadLink.setAttribute("href", "#"); | |
uploadLink.addEventListener("click", function(e){ | |
e = e || window.event; | |
contentGist.textContent = "Uploading..."; | |
contentGist.style.fontStyle = "italic"; | |
var data = { | |
"description": null, | |
"public": false, | |
"files": { | |
"debug_log.js": { | |
"content": JSON.stringify(ytcenter.getDebug(false), undefined, 2) | |
} | |
} | |
}; | |
ytcenter.utils.xhr({ | |
method: "POST", | |
url: "https://api.github.com/gists", | |
headers: { | |
"Content-Type": "application/x-www-form-urlencoded" | |
}, | |
data: JSON.stringify(data), | |
contentType: "application/x-www-form-urlencoded", // Firefox Addon | |
content: JSON.stringify(data), // Firefox Addon | |
onload: (function(contentGist){ | |
return function(response) { | |
var details = JSON.parse(response.responseText); | |
gistURL = details.html_url; | |
var link = document.createElement("a"); | |
link.href = gistURL; | |
link.textContent = gistURL; | |
contentGist.innerHTML = ""; | |
contentGist.style.fontStyle = ""; | |
contentGist.appendChild(link); | |
}; | |
})(contentGist) | |
}); | |
e && e.preventDefault && e.preventDefault(); | |
return false; | |
}, false); | |
} | |
if (!orSpan) { | |
orSpan = document.createElement("span"); | |
orSpan.textContent = " or "; | |
} | |
if (!useExistingLink) { | |
useExistingLink = document.createElement("a"); | |
useExistingLink.textContent = "use last Gist"; | |
useExistingLink.setAttribute("href", "#"); | |
useExistingLink.addEventListener("click", function(e){ | |
e = e || window.event; | |
var link = document.createElement("a"); | |
link.href = gistURL; | |
link.textContent = gistURL; | |
contentGist.innerHTML = ""; | |
contentGist.appendChild(link); | |
e && e.preventDefault && e.preventDefault(); | |
return false; | |
}, false); | |
} | |
//contentGist.appendChild(uploadLink); | |
if (gistURL) { | |
//contentGist.appendChild(orSpan); | |
//contentGist.appendChild(useExistingLink); | |
var link = document.createElement("a"); | |
link.href = gistURL; | |
link.textContent = gistURL; | |
contentGist.appendChild(link); | |
} else { | |
contentGist.appendChild(uploadLink); | |
} | |
item.appendChild(contentGist); | |
content = contentGist; | |
} else { | |
content = document.createElement("span"); | |
content.textContent = generatedContent; | |
} | |
item.appendChild(content); | |
if (listItem.addSpace) { | |
item.appendChild(document.createElement("br")); | |
item.appendChild(document.createElement("br")); | |
} | |
if (listItem.addLines) { | |
item.appendChild(document.createElement("br")); | |
item.appendChild(document.createElement("br")); | |
item.appendChild(document.createElement("br")); | |
} | |
list.appendChild(item); | |
} | |
tempElement.appendChild(list); | |
} | |
function getBrowserDetails() { | |
var parser = new ytcenter.UAParser(); | |
var results = parser.getResult(); | |
return results; | |
} | |
function getBrowserName() { | |
return browserDetails.browser.name; | |
} | |
function getBrowserVersion() { | |
return browserDetails.browser.version; | |
} | |
function getBrowserEngine() { | |
return browserDetails.engine.name; | |
} | |
function getOS() { | |
var name = browserDetails.os.name; | |
var version = browserDetails.os.version; | |
var returns = ""; | |
if (name) { | |
returns += name; | |
if (version) { | |
returns += " " + version; | |
} | |
} | |
return returns; | |
} | |
function getYTCVersion() { | |
if (devbuild) { | |
return "Developer Version - Build #" + devnumber; | |
} else { | |
return ytcenter.version; | |
} | |
} | |
function getAddonType() { | |
switch (identifier) { | |
case 0: | |
return "Userscript"; | |
case 1: | |
return "Chrome extension"; | |
case 2: | |
return "Maxthon extension"; | |
case 3: | |
return "Opera extension"; | |
case 4: | |
return "Firefox addon"; | |
case 5: | |
return "Userscript; Scriptish version"; | |
case 6: | |
return "Chrome extension; Webstore edition"; | |
default: | |
return ""; | |
} | |
} | |
function emptyTemplate() { | |
return ""; | |
} | |
function getDebugLog() { | |
return "```JavaScript\n" + JSON.stringify(ytcenter.getDebug(false), undefined, 2) + "\n```"; | |
} | |
var cat = null; | |
var browserDetails = null; | |
var gistURL = null; | |
// Gist URL action elements | |
var contentGist = null; | |
var uploadLink = null; | |
var orSpan = null; | |
var useExistingLink = null; | |
var templateList = [ | |
{ title: "Browser name", value: getBrowserName }, | |
{ title: "Browser version", value: getBrowserVersion }, | |
{ title: "Browser engine", value: getBrowserEngine, emptyHide: true }, | |
{ title: "OS", value: getOS, emptyHide: true }, | |
{ title: "YouTube Center version", value: getYTCVersion }, | |
{ title: "Addon type", value: getAddonType }, | |
{ title: "Debug log", value: getDebugLog, wrapper: "pre" }, | |
{ title: "Issue description", value: emptyTemplate, addLines: true }, | |
{ title: "How to reproduce the issue", value: emptyTemplate, addLines: true } | |
]; | |
var exports = {}; | |
exports.createSettingsCategory = createSettingsCategory; | |
exports.resetGistURL = function(){ gistURL = null; }; | |
return exports; | |
})(); | |
ytcenter.playerInstance = (function(){ | |
function setter(func) { | |
return func; | |
} | |
function setProperty(key, setter, getter) { | |
if (ytplayer[key]) { | |
con.log("[Player Instance] Overwriting existing value."); | |
} | |
defineLockedProperty(ytplayer, key, setter, getter); | |
} | |
var ytplayer = (uw.ytplayer = uw.ytplayer || {}); | |
var exports = {}; | |
exports.setProperty = setProperty; | |
return exports; | |
})(); | |
ytcenter.html5PlayWrapper = (function(){ | |
function init() { | |
try { | |
if (!originalPlayFunc) originalPlayFunc = HTMLVideoElement.prototype.play; | |
HTMLVideoElement.prototype.play = play; | |
// Checking if the play function was successfully written to the HTMLVideoElement prototype. | |
if (HTMLVideoElement.prototype.play === play) { | |
initialized = true; | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
function setReady(ready, spf) { | |
isReady = ready; | |
if (spf) isSPF = true; | |
} | |
function setForcedPause(bool) { | |
forcePause = bool; | |
} | |
function setForcedStop(bool) { | |
forceStop = bool; | |
} | |
function isInitialized() { | |
return initialized; | |
} | |
function play() { | |
if ((ytcenter.player.isPreventAutoBuffering() && !isReady) || forceStop) { | |
HTMLVideoElement.prototype.pause.apply(this, arguments); | |
var api = ytcenter.player.getAPI(); | |
if (api && api.stopVideo) { | |
api.stopVideo(); | |
ytcenter.player.fixThumbnailOverlay(-1); | |
} | |
if (isSPF) { | |
isReady = true; | |
} | |
} else if ((ytcenter.player.isPreventAutoPlay() && !isReady) || forcePause) { | |
var expPlayer = ytcenter.utils.hasClass(document.body, "exp-watch-controls-overlay"); | |
if (expPlayer) { | |
originalPlayFunc.apply(this, arguments); | |
} else { | |
HTMLVideoElement.prototype.pause.apply(this, arguments); | |
} | |
var api = ytcenter.player.getAPI(); | |
if (api && api.pauseVideo && expPlayer) { | |
setTimeout(function(){ | |
api.pauseVideo(); | |
}, 7); | |
} else if (api && api.pauseVideo && !expPlayer) { | |
api.pauseVideo(); | |
} | |
if (isSPF) { | |
isReady = true; | |
} | |
} else { | |
// Call the original play function | |
originalPlayFunc.apply(this, arguments); | |
} | |
} | |
var originalPlayFunc = null; | |
var isReady = false; | |
var isSPF = false; | |
var forcePause = false; | |
var forceStop = false; | |
var initialized = false; | |
init(); | |
var exports = {}; | |
exports.setReady = setReady; | |
exports.isInitialized = isInitialized; | |
exports.setForcedPause = setForcedPause; | |
exports.setForcedStop = setForcedStop; | |
return exports; | |
})(); | |
ytcenter.updateLogoLink_ = null; | |
ytcenter.updateLogoLink = function(){ | |
var logoContainer = document.getElementById("logo-container"), | |
url = ytcenter.settings.logoLink; | |
if (logoContainer && logoContainer.tagName === "A") { | |
if (ytcenter.updateLogoLink_ === null) { | |
ytcenter.updateLogoLink_ = logoContainer.getAttribute("href"); | |
} | |
if (ytcenter.updateLogoLink_ !== "/" && (url.indexOf("http://") === 0 || url.indexOf("https://") === 0)) { | |
url = ytcenter.updateLogoLink_.substring(0, ytcenter.updateLogoLink_.indexOf("http")) + url; | |
} else if (ytcenter.updateLogoLink_ !== "/") { | |
if (url.indexOf("/") === 0) url = url.substring(1); | |
url = ytcenter.updateLogoLink_ + url; | |
} | |
logoContainer.setAttribute("href", url); | |
} else if (logoContainer) { | |
var map = logoContainer.getElementsByTagName("map"); | |
if (map && map.length > 0 && map[0] && map[0].children && map[0].children.length > 0) { | |
if (ytcenter.updateLogoLink_ === null) ytcenter.updateLogoLink_ = map[0].children[0].getAttribute("href"); | |
if (ytcenter.updateLogoLink_ !== "/" && (url.indexOf("http://") === 0 || url.indexOf("https://") === 0)) { | |
url = ytcenter.updateLogoLink_.substring(0, ytcenter.updateLogoLink_.indexOf("http")) + url; | |
} else if (ytcenter.updateLogoLink_ !== "/") { | |
if (url.indexOf("/") === 0) url = url.substring(1); | |
url = ytcenter.updateLogoLink_ + url; | |
} | |
map[0].children[0].setAttribute("href", url); | |
} | |
} | |
}; | |
/** | |
* A wrapper for spfjs on YouTube. | |
* @URL https://github.com/youtube/spfjs/ | |
*/ | |
ytcenter.spf = (function(){ | |
function bind(scope, func) { | |
var args = Array.prototype.slice.call(arguments, 2); | |
return function(){ | |
return func.apply(scope, args.concat(Array.prototype.slice.call(arguments))) | |
}; | |
} | |
function navigateWrapper(url, opt_options) { | |
if (opt_options) { | |
con.warn("opt_options are not supported in the navigateWrapper", url, opt_options); | |
} | |
loc.href = url; | |
} | |
function setEnabled(enabled) { | |
if (enabled) { | |
!isEnabled() && uw && uw.spf && uw.spf.init && uw.spf.init(); | |
if (spfNavigate) { | |
uw.spf.navigate = spfNavigate; | |
} | |
if (spfElements) { | |
for (var i = 0, len = spfElements.length; i < len; i++) { | |
ytcenter.utils.addClass(spfElements[i], "spf-link"); | |
} | |
} | |
} else { | |
isEnabled() && uw && uw.spf && uw.spf.dispose && uw.spf.dispose(); | |
if (uw && uw.spf && uw.spf.navigate) { | |
spfNavigate = uw.spf.navigate; | |
uw.spf.navigate = navigateWrapper; | |
} | |
if (!spfElements) { | |
spfElements = document.getElementsByClassName("spf-link"); | |
} | |
for (var i = 0, len = spfElements.length; i < len; i++) { | |
ytcenter.utils.removeClass(spfElements[i], "spf-link"); | |
} | |
} | |
} | |
function isEnabled() { | |
return (uw && uw._spf_state && uw._spf_state["history-init"]); | |
} | |
function addEventListener(event, callback) { | |
if (!attachedEvents[event]) attachedEvents[event] = []; | |
attachedEvents[event].push(callback); | |
} | |
function removeEventListener(event, callback) { | |
if (!attachedEvents[event]) return; | |
for (var i = 0, len = attachedEvents[event].length; i < len; i++) { | |
if (attachedEvents[event][i] === callback) { | |
attachedEvents[event].splice(i, 1); | |
i--; len--; | |
} | |
} | |
} | |
function listener(event) { | |
var args = Array.prototype.slice.call(arguments, 1); | |
var detail = null; | |
if (args.length > 0 && args[0] && args[0].detail) { | |
detail = args[0].detail; | |
} | |
con.log("[SPF] " + event, detail); | |
var listeners = attachedEvents[event]; | |
if (listeners) { | |
for (var i = 0, len = listeners.length; i < len; i++) { | |
listeners[i].apply(this, args); | |
} | |
} | |
} | |
function init() { | |
for (var i = 0, len = spfEvents.length; i < len; i++) { | |
var boundListener = bind(null, listener, spfEvents[i]); | |
events.push(boundListener); | |
document.addEventListener(customEventPrefix + spfEvents[i], boundListener, false); | |
} | |
} | |
function dispose() { | |
if (events.length === spfEvents.length) { | |
for (var i = 0, len = spfEvents.length; i < len; i++) { | |
document.removeEventListener(customEventPrefix + spfEvents[i], events[i], false); | |
} | |
events = []; | |
} | |
} | |
var customEventPrefix = "spf"; | |
var spfEvents = [ "cssbeforeunload", "cssunload", "done", "error", "history", "jsbeforeunload", "jsunload", "partdone", "partprocess", "process", "ready", "reload", "request" ]; | |
var attachedEvents = { }; | |
var events = [ ]; | |
var spfNavigate = null; | |
var spfElements = null; | |
init(); | |
var exports = {}; | |
exports.addEventListener = addEventListener; | |
exports.removeEventListener = removeEventListener; | |
exports.setEnabled = setEnabled; | |
exports.isEnabled = isEnabled; | |
exports.init = init; | |
exports.dispose = dispose; | |
return exports; | |
})(); | |
loc = (function(){ | |
try { | |
if (typeof location !== "undefined") return location; | |
if (typeof window !== "undefined" && typeof window.location !== "undefined") return window.location; | |
if (typeof uw !== "undefined" && typeof uw.location !== "undefined") return uw.location; | |
} catch (e) {} | |
})(); | |
if (loc.href.indexOf("http://apiblog.youtube.com/") === 0 || loc.href.indexOf("https://apiblog.youtube.com/") === 0) return; | |
ytcenter.protocol = loc.href.indexOf("https://") === 0 ? "https://" : "http://"; | |
if (typeof console !== "undefined" && typeof console.log !== "undefined") { | |
con = {}; | |
for (var key in console) { | |
if (typeof console[key] === "function") { | |
con[key] = (function(key){ | |
return function(){ | |
try { | |
var args = []; | |
var _args = []; | |
for (var i = 0; i < arguments.length; i++) { | |
args.push(arguments[i]); | |
} | |
if (key === "error" && args[0]) { | |
var tmp = {args: args.length === 1 ? args[0] : args, type: "error"}; | |
if (args[0].message) { | |
tmp['message'] = args[0].message; | |
} | |
if (args[0].stack) { | |
tmp['stack'] = args[0].stack; | |
} | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push(tmp); | |
} | |
if (tmp['stack']) { | |
_args = [args[0].stack]; | |
} else if (tmp['message']) { | |
_args = [args[0].message]; | |
} else { | |
_args = args; | |
} | |
} else { | |
_args = args; | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push({args: _args.length === 1 ? _args[0] : _args, type: key}); | |
} | |
} | |
if (console_debug && console[key].apply) { | |
return console[key].apply(console, args) | |
} else if (console_debug) { | |
return console[key](_args[0]); | |
} | |
} catch (e) { | |
console.error(e); | |
} | |
}; | |
})(key); | |
} | |
} | |
} else if (typeof uw.console !== "undefined" && typeof uw.console.log !== "undefined") { | |
con = {}; | |
for (var key in uw.console) { | |
if (typeof uw.console[key] === "function") { | |
con[key] = (function(key){ | |
return function(){ | |
try { | |
var args = []; | |
var _args = []; | |
for (var i = 0; i < arguments.length; i++) { | |
args.push(arguments[i]); | |
} | |
if (key === "error" && args[0]) { | |
var tmp = {args: args.length === 1 ? args[0] : args, type: "error"}; | |
if (args[0].message) { | |
tmp['message'] = args[0].message; | |
} | |
if (args[0].stack) { | |
tmp['stack'] = args[0].stack; | |
} | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push(tmp); | |
} | |
if (tmp['stack']) { | |
_args = [args[0].stack]; | |
} else if (tmp['message']) { | |
_args = [args[0].message]; | |
} else { | |
_args = args; | |
} | |
} else { | |
_args = args; | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push({args: _args.length === 1 ? _args[0] : _args, type: key}); | |
} | |
} | |
if (console_debug && uw.console[key].apply) { | |
return uw.console[key].apply(uw.console, _args); | |
} else if (console_debug) { | |
return uw.console[key](_args[0]); | |
} | |
} catch (e) { | |
console.error(e); | |
} | |
}; | |
})(key); | |
} | |
} | |
} else { | |
con = {}; | |
for (var key in console) { | |
if (typeof console[key] === "function") { | |
con[key] = (function(key){ | |
return function(msg){ | |
try { | |
var args = []; | |
var _args = []; | |
for (var i = 0; i < arguments.length; i++) { | |
args.push(arguments[i]); | |
} | |
if (key === "error" && args[0]) { | |
var tmp = {args: args.length === 1 ? args[0] : args, type: "error"}; | |
if (args[0].message) { | |
tmp['message'] = args[0].message; | |
} | |
if (args[0].stack) { | |
tmp['stack'] = args[0].stack; | |
} | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push(tmp); | |
} | |
if (tmp['stack']) { | |
_args = [args[0].stack]; | |
} else if (tmp['message']) { | |
_args = [args[0].message]; | |
} else { | |
_args = args; | |
} | |
} else { | |
_args = args; | |
if (!(ytcenter && ytcenter.settings && !ytcenter.settings.debugConsole)) { | |
_console.push({args: _args.length === 1 ? _args[0] : _args, type: key}); | |
} | |
} | |
if (console_debug && GM_log.apply) { | |
return GM_log.apply(this, _args); | |
} else { | |
return GM_log(_args[0]); | |
} | |
} catch (e) { | |
console.error(e); | |
} | |
}; | |
})(key); | |
} | |
} | |
} | |
ytcenter.actionPanel = (function(){ | |
function getEventListener(options) { | |
if (ytcenter.feather) return null; | |
if (typeof uw.yt === "undefined" || typeof uw.yt.events === "undefined" || typeof uw.yt.events.listeners_ === "undefined") return null; | |
var key, item = null; | |
var listeners = uw.yt.events.listeners_; | |
for (key in listeners) { | |
item = listeners[key]; | |
if (item && item.length > 1 && options.element === item[0] && options.event === item[1]) { | |
return item; | |
} | |
} | |
item = null; | |
return null; | |
} | |
function likeButtonListener(e) { | |
function switchToPreferredTab() { | |
setPanelEnabled("share", true); | |
uw.setTimeout(function(){ switchTo(ytcenter.settings.likeSwitchToTab); }, 7); | |
} | |
if (ytcenter.feather) return; | |
try { | |
var isLiked = ytcenter.utils.hasClass(document.getElementById("watch-like-dislike-buttons"), "liked"); | |
setPanelEnabled("share", false); | |
originalEventListener(e); | |
if (ytcenter.settings.likeSwitchToTab !== "none" && !isLiked) { | |
uw.setTimeout(switchToPreferredTab, 7); | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
function setPanelEnabled(panel, enabled) { | |
if (enabled) { | |
var el = document.getElementById("action-panel-" + panel + "-disabled"); | |
if (el) { | |
el.setAttribute("id", "action-panel-" + panel); | |
} | |
} else { | |
var el = document.getElementById("action-panel-" + panel); | |
if (el) { | |
el.setAttribute("id", "action-panel-" + panel + "-disabled"); | |
} | |
} | |
} | |
function switchTo(panel) { | |
if (!panel || panel === "none") return; | |
var btn = document.createElement("button"); | |
btn.className = "action-panel-trigger"; | |
btn.setAttribute("data-trigger-for", "action-panel-" + panel); | |
var parent = document.getElementById("watch8-action-buttons"); | |
parent.appendChild(btn); | |
btn.click(); | |
parent.removeChild(btn); | |
} | |
function getLikeButton() { | |
return document.getElementById("watch-like"); | |
} | |
function setup() { | |
if (ytcenter.feather) return; | |
if (maxSetupCalls < setupCalls) return; | |
setupCalls++; | |
try { | |
if (likeButton && likeButtonListener && likeButtonEvent) { | |
likeButton.removeEventListener("click", likeButtonListener, likeButtonEvent[4]); | |
} | |
if (ytcenter.getPage() !== "watch") return; | |
con.log("[ActionPanel] Loading..."); | |
likeButton = getLikeButton(); | |
likeButtonEvent = getEventListener({ event: "click", element: likeButton }); | |
if (likeButton === null || likeButtonEvent === null || typeof likeButtonEvent[3] !== "function") { | |
uw.setTimeout(function(){ setup(); }, 2500); | |
return; | |
} | |
con.log("[ActionPanel] Setup has begun!"); | |
originalEventListener = likeButtonEvent[3]; | |
con.log("[ActionPanel] Adding/Removing listeners"); | |
likeButton.removeEventListener("click", originalEventListener, likeButtonEvent[4]); | |
ytcenter.utils.addEventListener(likeButton, "click", likeButtonListener, likeButtonEvent[4]); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
var enabled = true; | |
var switchToElm = null; | |
var observer = null; | |
var originalEventListener = null; | |
var likeButton = null; | |
var likeButtonEvent = null; | |
var delayedSwitchTabTimer = null; | |
var maxSetupCalls = 10; | |
var setupCalls = 0; | |
return { | |
switchTo: switchTo, | |
setup: setup | |
}; | |
})(); | |
ytcenter.mutation = (function(){ | |
var exports = {}, | |
M = null, | |
setup = false, | |
disconnects = [], | |
disconnected = false; | |
exports.fallbackObserve = function(target, options, callback){ | |
function MutationRecord(record) { | |
this.addedNodes = record.addedNodes || null; | |
this.attributeName = record.attributeName || null; | |
this.attributeNamespace = record.attributeNamespace || null; | |
this.nextSibling = record.nextSibling || null; | |
this.oldValue = record.oldValue || null; | |
this.previousSibling = record.previousSibling || null; | |
this.removedNodes = record.removedNodes || null; | |
this.target = record.target || null; | |
this.type = record.type || null; | |
this.event = record.event || null; | |
} | |
function c() { | |
if (insertedNodes.length > 0 || removedNodes.length > 0) { | |
mutationRecords.push(new MutationRecord({ | |
addedNodes: insertedNodes, | |
removedNodes: removedNodes, | |
type: "childList", | |
target: target | |
})); | |
} | |
if (attributes.length > 0) { | |
for (i = 0; i < attributes.length; i++) { | |
mutationRecords.push(new MutationRecord({ | |
attributeName: attributes[i].attributeName, | |
attributeNamespace: attributes[i].attributeNamespace, | |
oldValue: attributes[i].oldValue, | |
type: "attributes", | |
target: target | |
})); | |
} | |
} | |
if (attributes.length > 0) { | |
for (i = 0; i < attributes.length; i++) { | |
mutationRecords.push(new MutationRecord({ | |
attributeName: attributes[i].attributeName, | |
attributeNamespace: attributes[i].attributeNamespace, | |
oldValue: attributes[i].oldValue, | |
type: "attributes", | |
target: target | |
})); | |
} | |
} | |
if (characterDataModified) { | |
mutationRecords.push(new MutationRecord({ | |
oldValue: characterDataModified.oldValue, | |
type: "characterData", | |
target: target | |
})); | |
} | |
if (characterDataModified) { | |
mutationRecords.push(new MutationRecord({ | |
oldValue: characterDataModified.oldValue, | |
type: "characterData", | |
target: target | |
})); | |
} | |
if (subtreeModified) { | |
mutationRecords.push(new MutationRecord({ | |
type: "subtree", | |
target: target | |
})); | |
} | |
callback(mutationRecords); | |
// Cleaning up | |
insertedNodes = []; | |
removedNodes = []; | |
mutationRecords = []; | |
attributes = []; | |
characterDataModified = null; | |
subtreeModified = false; | |
if (failsafe && !disconnected) { | |
addListeners(); | |
} | |
} | |
function DOMNodeInserted(e) { | |
insertedNodes.push(e.target); | |
wrapperFunction(); | |
} | |
function DOMNodeRemoved(e) { | |
removedNodes.push(e.target); | |
wrapperFunction(); | |
} | |
function DOMAttrModified(e) { | |
attributes.push({ | |
attributeName: e.attrName, | |
attributeNamespace: e.attrName, | |
oldValue: e.prevValue | |
}); | |
wrapperFunction(); | |
} | |
function DOMCharacterDataModified(e) { | |
characterDataModified = { | |
newValue: e.newValue, | |
oldValue: e.prevValue | |
}; | |
wrapperFunction(); | |
} | |
function DOMSubtreeModified(e) { | |
subtreeModified = true; | |
wrapperFunction(); | |
} | |
function addListeners() { | |
if (options.childList) { | |
ytcenter.utils.addEventListener(target, "DOMNodeInserted", DOMNodeInserted, false); | |
ytcenter.utils.addEventListener(target, "DOMNodeRemoved", DOMNodeRemoved, false); | |
} | |
if (options.attributes) { | |
ytcenter.utils.addEventListener(target, "DOMAttrModified", DOMAttrModified, false); | |
} | |
if (options.characterData) { | |
ytcenter.utils.addEventListener(target, "DOMCharacterDataModified", DOMCharacterDataModified, false); | |
} | |
if (options.subtree) { | |
ytcenter.utils.addEventListener(target, "DOMSubtreeModified", DOMSubtreeModified, false); | |
} | |
} | |
function removeListeners() { | |
disconnected = true; | |
if (options.childList) { | |
ytcenter.utils.removeEventListener(target, "DOMNodeInserted", DOMNodeInserted, false); | |
ytcenter.utils.removeEventListener(target, "DOMNodeRemoved", DOMNodeRemoved, false); | |
} | |
if (options.attributes) { | |
ytcenter.utils.removeEventListener(target, "DOMAttrModified", DOMAttrModified, false); | |
} | |
if (options.characterData) { | |
ytcenter.utils.removeEventListener(target, "DOMCharacterDataModified", DOMCharacterDataModified, false); | |
} | |
if (options.subtree) { | |
ytcenter.utils.removeEventListener(target, "DOMSubtreeModified", DOMSubtreeModified, false); | |
} | |
} | |
function wrapperFunction(){ | |
if (failsafe) { | |
removeListeners(); | |
} | |
throttleFunc(); | |
} | |
var buffer = null, i, | |
insertedNodes = [], | |
removedNodes = [], | |
mutationRecords = [], | |
attributes = [], | |
characterDataModified = null, | |
subtreeModified = false, | |
throttleFunc = ytcenter.utils.throttle(c, 500), | |
failsafe = true; | |
if (typeof options.failsafe === "boolean") { | |
failsafe = options.failsafe; | |
} | |
addListeners(); | |
return disconnects[disconnects.push({ | |
DOMNodeInserted: DOMNodeInserted, | |
DOMNodeRemoved: DOMNodeRemoved, | |
DOMAttrModified: DOMAttrModified, | |
DOMCharacterDataModified: DOMCharacterDataModified, | |
DOMSubtreeModified: DOMSubtreeModified, | |
target: target, | |
options: options, | |
callback: callback, | |
disconnect: removeListeners | |
}) - 1]; | |
}; | |
exports.observe = function(target, options, callback){ | |
function mutationCallback(mutations) { | |
// Disconnecting observer to prevent an infinite loop | |
if (failsafe) { | |
observer.disconnect(); | |
} | |
callback(mutations); | |
if (failsafe && !disconnected) { | |
observer.observe(target, options); | |
} | |
} | |
function finishedCalling() { | |
calling = false; | |
} | |
var calling = false, | |
failsafe = true; | |
if (!target || !options || !callback) return; | |
if (typeof options.failsafe === "boolean") { | |
failsafe = options.failsafe; | |
} | |
if (!setup) exports.setup(); | |
//if (!M) return exports.fallbackObserve(target, options, callback); // fallback if MutationObserver isn't supported | |
//if (!M) throw "MutationObserver not supported."; | |
var observer = null; | |
if (M) observer = new M(mutationCallback); | |
var disconnected = false; | |
if (observer) observer.observe(target, options); | |
return disconnects[disconnects.push({ | |
target: target, | |
options: options, | |
callback: callback, | |
disconnect: function(){ | |
disconnected = true; | |
if (observer) observer.disconnect(); | |
} | |
}) - 1]; | |
}; | |
exports.disconnect = function(target, callback){ | |
var i; | |
for (i = 0; i < disconnects.length; i++) { | |
if (target === disconnects[i].target && callback === disconnects[i].callback) { | |
disconnects[i].disconnect(); | |
} | |
} | |
}; | |
exports.setup = function(){ | |
setup = true; | |
M = ytcenter.getMutationObserver(); | |
ytcenter.unload(function(){ | |
var i; | |
for (i = 0; i < disconnects.length; i++) { | |
if (disconnects[i] && disconnects[i].disconnect) disconnects[i].disconnect(); | |
} | |
}); | |
}; | |
return exports; | |
})(); | |
try { | |
ytcenter.embed = {}; | |
ytcenter.embed.isYouTubeReady = false; | |
ytcenter.embed.isYouTubeCenterReady = false; | |
ytcenter.embed.failsafe = false; | |
ytcenter.embed._writeEmbed = uw.writeEmbed; | |
defineLockedProperty(uw, "writeEmbed", function(func){ | |
con.log("[Embed] writeEmbed has been leaked to YouTube Center Developer Build."); | |
ytcenter.embed._writeEmbed = func; | |
}, function(){ | |
if (ytcenter.embed.failsafe) | |
return ytcenter.embed._writeEmbed; | |
return function(){ | |
con.log("[Embed] YouTube has called writeEmbed."); | |
ytcenter.embed.isYouTubeReady = true; | |
if (ytcenter.embed.writePlayer) | |
ytcenter.embed.writePlayer(); | |
}; | |
}); | |
ytcenter.embed.callWriteEmbed = function(){ | |
var reload = false; | |
try { | |
if (ytcenter.settings.embedWriteEmbedMethod === "standard") { // Async | |
ytcenter.embed._writeEmbed(); | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test1") { // Async | |
uw.yt.player.embed("player", ytcenter.player.getConfig()); | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test2") { // Sync | |
var data = new uw.yt.player.Application("player", ytcenter.player.getConfig()); | |
con.log("[callWriteEmbed]", data); | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test3") { // Sync | |
uw.yt.player.Application.create("player", ytcenter.player.getConfig()); | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "standard+reload") { // Async | |
ytcenter.embed._writeEmbed(); | |
reload = true; | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test1+reload") { // Async | |
uw.yt.player.embed("player", ytcenter.player.getConfig()); | |
reload = true; | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test2+reload") { // Sync | |
var data = new uw.yt.player.Application("player", ytcenter.player.getConfig()); | |
con.log("[callWriteEmbed]", data); | |
reload = true; | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test3+reload") { // Sync | |
uw.yt.player.Application.create("player", ytcenter.player.getConfig()); | |
reload = true; | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test4") { // Sync | |
uw.ytcenter_writeEmbed = ytcenter.embed._writeEmbed; | |
ytcenter.inject(function(){ | |
var c = JSON.parse(JSON.stringify(ytplayer.config)); | |
yt.config_.PLAYER_CONFIG = c; | |
ytcenter_writeEmbed(); | |
}); | |
} else if (ytcenter.settings.embedWriteEmbedMethod === "test5") { // Sync | |
try { | |
uw.yt.config_.PLAYER_CONFIG = ytcenter.utils.jsonClone(ytcenter.player.getConfig()); | |
} catch (e) { | |
con.error(e); | |
} | |
ytcenter.embed._writeEmbed(); | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
if (reload) { | |
// Reload the embedded video if there is no children of the player element after 1.0 seconds. | |
uw.setTimeout(function(){ | |
var p = document.getElementById("player"); | |
if (!p) return; | |
if (p.children.length === 0) { | |
loc.reload(); | |
} | |
}, ytcenter.settings.embedWriteEmbedMethodReloadDelay); | |
} | |
}; | |
ytcenter.embed.writePlayer = function(){ | |
try { | |
if (typeof ytcenter.embed._writeEmbed !== "function") { | |
con.log("[Embed] writeEmbed is not yet ready!"); | |
return; | |
} | |
con.log("[Embed] Checking if YouTube and YouTube Center Developer Build are ready..."); | |
if (!ytcenter.embed.isYouTubeReady || !ytcenter.embed.isYouTubeCenterReady) { | |
con.log("[Embed] They're both not ready yet!"); | |
return; | |
} | |
/* Settings the player config according to YouTube Center Developer Build */ | |
var cfg = ytcenter.player.getConfig(); | |
if (cfg) uw.yt.config_.PLAYER_CONFIG = cfg; | |
/* Writing the embedded player */ | |
con.log("[Embed] Writing the embedded player."); | |
ytcenter.embed.callWriteEmbed(); | |
} catch (e) { | |
con.error(e); | |
ytcenter.embed.failsafe = true; | |
/* Trying to write the player when an error was thrown */ | |
try { | |
con.log("[Embed] Writing the embedded player."); | |
ytcenter.embed.callWriteEmbed(); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
}; | |
ytcenter.embed.load = function(){ | |
try { | |
var url = ytcenter.player.getVideoDataRequest(); | |
con.log("[Embed] Downloading data from " + url); | |
ytcenter.utils.xhr({ | |
method: "GET", | |
url: url, | |
headers: { | |
"Content-Type": "text/plain" | |
}, | |
onload: function(response){ | |
try { | |
if (response.responseText) { | |
con.log("[Embed] Download complete."); | |
var object = {}, tokens = response.responseText.split("&"); | |
for (var i = 0; i < tokens.length; i++) { | |
var ss = tokens[i].split("="); | |
object[ss[0]] = decodeURIComponent(ss[1]); | |
} | |
if (object.errorcode) { | |
con.error("[Embed] Error: " + object.errorcode + ": " + object.reason); | |
} else { | |
if (object.dash) ytcenter.player.config.args.dash = object.dash; | |
if (object.dashmpd) ytcenter.player.config.args.dashmpd = object.dashmpd; | |
if (object.adaptive_fmts) ytcenter.player.config.args.adaptive_fmts = object.adaptive_fmts; | |
if (object.fmt_list) ytcenter.player.config.args.fmt_list = object.fmt_list; | |
if (object.url_encoded_fmt_stream_map) ytcenter.player.config.args.url_encoded_fmt_stream_map = object.url_encoded_fmt_stream_map; | |
if (object.url_encoded_fmt_stream_map || object.adaptive_fmts) { | |
ytcenter.video.streams = ytcenter.parseStreams(object); | |
} | |
ytcenter.player.setConfig(ytcenter.player.modifyConfig("embed", ytcenter.player.config)); | |
} | |
ytcenter.embed.isYouTubeCenterReady = true; | |
ytcenter.embed.writePlayer(); | |
} else { | |
con.error("[Embed] Didn't receive any data!"); | |
ytcenter.embed.failsafe = true; | |
/* Going to set YouTube Center Developer Build as ready to make it possible for the user to watch the embedded video if possible. */ | |
ytcenter.embed.isYouTubeCenterReady = true; | |
ytcenter.embed.writePlayer(); | |
} | |
} catch (e) { | |
con.error(e); | |
ytcenter.embed.failsafe = true; | |
/* Just to make people happy. */ | |
ytcenter.embed.isYouTubeCenterReady = true; | |
ytcenter.embed.writePlayer(); | |
} | |
}, | |
onerror: function(){ | |
con.error("[Embed] Connection failed!"); | |
ytcenter.embed.failsafe = true; | |
/* Going to set YouTube Center Developer Build as ready to make it possible for the user to watch the embedded video if possible. */ | |
ytcenter.embed.isYouTubeCenterReady = true; | |
ytcenter.embed.writePlayer(); | |
} | |
}); | |
} catch (e) { | |
con.error(e); | |
ytcenter.embed.failsafe = true; | |
ytcenter.embed.isYouTubeCenterReady = true; | |
ytcenter.embed.writePlayer(); | |
} | |
}; | |
} catch (e) { | |
con.error(e); | |
} | |
ytcenter.io = {}; | |
ytcenter.unsafe.io = ytcenter.io; | |
ytcenter.title = {}; | |
ytcenter.title.originalTitle = ""; | |
ytcenter.title.previousTitle = ""; | |
ytcenter.title.liveTitle = ""; | |
ytcenter.title.processOriginalTitle = function(a){ | |
if (ytcenter.player && ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.title) { | |
// Doesn't have a prefix or suffix. | |
a = ytcenter.player.config.args.title; | |
} else { | |
// Can have prefix and suffix. | |
a = a.replace(/^\u25b6 /, ""); // Removes the prefix. | |
// The suffix is handled in the update process. | |
} | |
return a; | |
}; | |
ytcenter.title.modified = function(){ | |
var a = document.getElementsByTagName("title")[0].textContent; | |
if (a !== ytcenter.title.previousTitle) { | |
if (ytcenter.title.originalTitle === "") { | |
ytcenter.title.originalTitle = ytcenter.title.processOriginalTitle(a); | |
} | |
con.log("[Title Listener] \"" + ytcenter.title.previousTitle + "\" => \"" + a + "\""); | |
ytcenter.title.previousTitle = a; | |
ytcenter.title.update(); | |
} | |
}; | |
ytcenter.title._init_count = 0; | |
ytcenter.title.init = function(){ | |
var a = document.getElementsByTagName("title")[0]; | |
if ((a && a.textContent && a.textContent !== "") || (document && document.title && document.title !== "")) { | |
ytcenter.title._init_count = 0; | |
if (a && a.textContent && a.textContent !== "") { | |
ytcenter.title.originalTitle = ytcenter.title.processOriginalTitle(a.textContent); | |
} else { | |
ytcenter.title.originalTitle = ytcenter.title.processOriginalTitle(document.title); | |
} | |
ytcenter.mutation.observe(document.head, { attributes: true, childList: true, characterData: true, subtree: true, failsafe: false }, ytcenter.title.modified); | |
ytcenter.title.update(); | |
} else { | |
if (ytcenter.title._init_count > 5) { | |
ytcenter.title._init_count = 0; | |
return; | |
} | |
con.log("[Title Listener] Waiting for title head..."); | |
ytcenter.title._init_count++; | |
uw.setTimeout(ytcenter.title.init, 500); | |
} | |
}; | |
ytcenter.title.update = function(){ | |
if (ytcenter.title.originalTitle === "") return; | |
//var a = document.getElementsByTagName("title")[0]; | |
if (ytcenter.settings.playerPlayingTitleIndicator && ytcenter.getPage() === "watch") { | |
if (ytcenter.player.getAPI && ytcenter.player.getAPI() && ytcenter.player.getAPI().getPlayerState && ytcenter.player.getAPI().getPlayerState() === 1) { | |
ytcenter.title.addPlayIcon(); | |
} else { | |
ytcenter.title.removePlayIcon(); | |
} | |
} else { | |
ytcenter.title.removePlayIcon(); | |
} | |
if (ytcenter.settings.removeYouTubeTitleSuffix) { | |
ytcenter.title.removeSuffix(); | |
} else { | |
ytcenter.title.addSuffix(); | |
} | |
try { | |
document.title = ytcenter.title.liveTitle; | |
} catch (e) { | |
con.error(e); | |
} | |
}; | |
ytcenter.title.hasSuffix = function(){ | |
return / - YouTube$/.test(ytcenter.title.liveTitle); | |
}; | |
ytcenter.title.removeSuffix = function(){ | |
ytcenter.title.liveTitle = ytcenter.title.liveTitle.replace(/ - YouTube$/, ""); | |
}; | |
ytcenter.title.addSuffix = function(){ | |
if (ytcenter.title.hasSuffix()) return; | |
ytcenter.title.liveTitle += " - YouTube"; | |
}; | |
ytcenter.title.hasPlayIcon = function(){ | |
return ytcenter.title.liveTitle.indexOf("\u25b6 ") === 0; | |
}; | |
ytcenter.title.removePlayIcon = function(){ | |
ytcenter.title.liveTitle = ytcenter.title.originalTitle; | |
}; | |
ytcenter.title.addPlayIcon = function(){ | |
ytcenter.title.liveTitle = "\u25b6 " + ytcenter.title.originalTitle; | |
}; | |
ytcenter.inject = function(func){ | |
try { | |
var script = document.createElement("script"), | |
p = (document.body || document.head || document.documentElement); | |
if (!p) { | |
con.error("[Script Inject] document.body, document.head and document.documentElement doesn't exist!"); | |
return; | |
} | |
if (typeof func === "string") { | |
func = "function(){" + func + "}"; | |
} | |
script.setAttribute("type", "text/javascript"); | |
script.appendChild(document.createTextNode("(" + func + ")();\n//# sourceURL=YouTubeCenter.js")); | |
p.appendChild(script); | |
p.removeChild(script); | |
} catch (e) { | |
con.error(e); | |
} | |
}; | |
ytcenter.insertStyle = function(href, name){ | |
var link = document.createElement("link"); | |
var parent = (document.body || document.head || document.documentElement); | |
link.setAttribute("rel", "stylesheet"); | |
link.setAttribute("href", href); | |
link.setAttribute("name", name); | |
parent.appendChild(link); | |
}; | |
ytcenter.insertScript = function(src, name){ | |
function onload() { | |
onloadFunc && onloadFunc(); | |
} | |
function setOnload(func) { | |
onloadFunc = func; | |
} | |
var onloadFunc = null; | |
var script = document.createElement("script"); | |
var parent = (document.body || document.head || document.documentElement); | |
script.setAttribute("type", "text/javascript"); | |
script.setAttribute("src", src); | |
script.setAttribute("name", name); | |
script.onload = onload; | |
script.onreadystatechange = function(){ | |
if (this.readyState === "complete") { | |
onload(); | |
} | |
}; | |
parent.appendChild(script); | |
return { | |
onload: setOnload | |
}; | |
}; | |
ytcenter.unload = (function(){ | |
var unloads = []; | |
window.addEventListener("unload", function(){ | |
var i; | |
for (i = 0; i < unloads.length; i++) { | |
if (typeof unloads[i] === "function") unloads[i](); | |
else con.error("[Unload] Couldn't unload!", unloads[i]); | |
} | |
}, false); | |
return function(unload){ | |
unloads.push(unload); | |
}; | |
})(); | |
ytcenter.version = "2.1.6"; | |
ytcenter.revision = 155; | |
ytcenter.icon = {}; | |
ytcenter.page = "none"; | |
ytcenter.feather = false; | |
ytcenter.icon.gear = ""; | |
ytcenter.icon.lightbulb = ""; | |
ytcenter.icon.smallThumbsUpWhite = ""; | |
ytcenter.icon.smallThumbsDownWhite = ""; | |
ytcenter.icon.likebuttonicon = ""; | |
ytcenter.icon.dislikebuttonicon = ""; | |
ytcenter.css = { | |
general: ".ytcenter-icon-thumbs-like{display:inline-block;border:0;width:11px;height:11px;background:url('') no-repeat center}.ytcenter-icon-thumbs-dislike{display:inline-block;border:0;width:11px;height:11px;background:url('') no-repeat center}body.ytcenter-site-watch.flex-width-enabled>* #page{min-width:0!important;max-width:none!important}div#page.watch-non-stage-mode #watch-appbar-playlist.watch-playlist.radio-playlist .playlist-videos-list{top:100px}body.ytcenter-hide-footer #footer-container{display:none}body.player-dock #player-api{position:fixed!important;z-index:10!important}body.player-dock #player-dock-offset{display:block!important}#player-dock-offset{display:none}body.hide-header-transition #masthead-positioner>*{transition:margin-top .6s;-moz-transition:margin-top .6s;-ms-transition:margin-top .6s;-o-transition:margin-top .6s;-webkit-transition:margin-top .6s}body.hide-header-transition #masthead-positioner-height-offset{transition:height .6s;-moz-transition:height .6s;-ms-transition:height .6s;-o-transition:height .6s;-webkit-transition:height .6s}body.hide-header-transition .appbar-guide-menu-layout{transition:margin-top .6s;-moz-transition:margin-top .6s;-ms-transition:margin-top .6s;-o-transition:margin-top .6s;-webkit-transition:margin-top .6s}body.hide-header #masthead-positioner>*{margin-top:-51px}body.hide-header .appbar-guide-menu-layout{margin-top:0}body.hide-header #masthead-positioner-height-offset,body.hide-header.appbar-hidden.ytcenter-ticker-hidden #masthead-positioner-height-offset{height:0!important;overflow:hidden}body.static-yt-logo #yt-masthead .doodle-removed #logo{background-position:-48px -478px!important}.yt-uix-button.yt-uix-button-subscribe-branded,.yt-uix-button.yt-uix-button-subscribed-branded{border-width:1px!important}#watch7-views-info{bottom:100%}#watch-description .ypc-offer-thumbnail{position:relative}.appbar-flexwatch .watch-stage-mode #player,.appbar-flexwatch-mini .watch-stage-mode #player{margin-top:10px!important}.hide-lang-alert #alerts #yt-lang-alert-container{display:none!important}.static-header #masthead-positioner{position:relative!important}.static-header #masthead-positioner-height-offset{display:none!important}a .ytcenter-video-thumb-show-hover{display:none}a:hover .ytcenter-video-thumb-show-hover{display:block}a .ytcenter-video-thumb-hide-hover{display:block}a:hover .ytcenter-video-thumb-hide-hover{display:none}.ytcenter-hue{position:absolute!important;top:0!important;background:-moz-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-ms-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-o-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-webkit-gradient(linear,left top,left bottom,from(#f00),color-stop(0.17,#ff0),color-stop(0.33,#0f0),color-stop(0.5,#0ff),color-stop(0.67,#00f),color-stop(0.83,#f0f),to(#f00))!important;background:-webkit-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important}.ytcenter-hue .ie-1{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000',endColorstr='#ffff00')}.ytcenter-hue .ie-2{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00',endColorstr='#00ff00')}.ytcenter-hue .ie-3{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00',endColorstr='#00ffff')}.ytcenter-hue .ie-4{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff',endColorstr='#0000ff')}.ytcenter-hue .ie-5{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff',endColorstr='#ff00ff')}.ytcenter-hue .ie-6{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff',endColorstr='#ff0000')}.ytcenter-range{position:relative;display:inline-block;overflow:hidden;border:1px solid #eee;outline:0;-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px}.ytcenter-range .ytcenter-range-handle{border-width:1px;border-style:solid;outline:0;font-weight:bold;font-size:11px;white-space:nowrap;word-wrap:normal;vertical-align:middle;border-top:0;border-bottom:0}.ytcenter-hue.ytcenter-range{border-color:#000}.ytcenter-hue.ytcenter-range .ytcenter-range-handle{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px}.ytcenter-range.ytcenter-hue .ytcenter-range-handle{border:0!important;-moz-border-radius:0!important;-webkit-border-radius:0!important;border-radius:0!important}.ytcenter-range.ytcenter-hue{border:0!important;outline:0;overflow:visible;-moz-border-radius:0!important;-webkit-border-radius:0!important;border-radius:0!important}.ytcenter-range-handle{position:absolute;top:0;cursor:default!important;margin:0;padding:0;text-shadow:0 1px 0 rgba(255,255,255,.5);border-color:#d3d3d3;background-color:#f8f8f8;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#fffcfcfc,EndColorStr=#fff8f8f8);background-image:-moz-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-ms-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-o-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#fcfcfc),color-stop(100%,#f8f8f8));background-image:-webkit-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:linear-gradient(to bottom,#fcfcfc 0,#f8f8f8 100%)}.ltr .ytcenter-range-handle{left:0}.rtl .ytcenter-range-handle{right:0}.ytcenter-range-handle .ytcenter-range-handle-left{position:absolute;top:-7px;width:0;height:0;border:solid transparent;border-width:7px}.ltr .ytcenter-range-handle .ytcenter-range-handle-left{left:-7px;border-left-color:#fff}.rtl .ytcenter-range-handle .ytcenter-range-handle-left{right:-7px;border-right-color:#fff}.ytcenter-range-handle .ytcenter-range-handle-right{position:absolute;top:-7px;left:7px;width:0;height:0;border:solid transparent;border-width:7px;border-right-color:#fff}.ltr .ytcenter-range-handle .ytcenter-range-handle-right{left:7px;border-right-color:#fff}.rtl .ytcenter-range-handle .ytcenter-range-handle-right{right:7px;border-left-color:#fff}.ytcenter-range.ytcenter-hue .ytcenter-range-handle .ytcenter-range-handle-right{border-top:7px solid transparent!important;border-bottom:7px solid transparent!important}.ltr .ytcenter-range.ytcenter-hue .ytcenter-range-handle .ytcenter-range-handle-right{border-right:7px solid #000!important}.rtl .ytcenter-range.ytcenter-hue .ytcenter-range-handle .ytcenter-range-handle-right{border-left:7px solid #000!important}.ytcenter-colorpicker{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;display:inline-block;width:16px;height:16px;cursor:pointer;border:1px solid #eee}.ytcenter-colorpicker-saturation{position:absolute;width:100%;height:100%;top:0;background-image:-webkit-gradient(linear,0 0,100% 0,from(#FFF),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(left,#FFF,rgba(204,154,129,0));background-image:-moz-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-o-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-ms-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:linear-gradient(to right,#fff,rgba(204,154,129,0));-ms-filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1,startColorstr='#FFFFFFFF, endColorstr=#00CC9A81');filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1,startColorstr='#FFFFFFFF',endColorstr='#00CC9A81')}.ltr .ytcenter-colorpicker-saturation,.lrt .ytcenter-colorpicker-value,.lrt .ytcenter-colorpicker-handler{left:0}.rtl .ytcenter-colorpicker-saturation,.rtl .ytcenter-colorpicker-value,.rtl .ytcenter-colorpicker-handler{right:0}.ytcenter-colorpicker-value{position:absolute;width:100%;height:100%;top:0;background-image:-webkit-gradient(linear,0 100%,0 0,from(#000),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-moz-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-o-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-ms-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:linear-gradient(to top,#000,rgba(204,154,129,0));-ms-filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81, endColorstr=#FF000000');filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81',endColorstr='#FF000000')}.ytcenter-colorpicker-handler{position:absolute;top:0;-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px;width:5px;height:5px;border:1px solid #fff;background:#000}.force-hid{display:none!important}.ytcenter-placement-section{border:1px solid #e6e6e6;border-top-width:0;border-bottom-width:0;padding:0 18px}body.ytcenter-branding-remove-banner #page.watch #guide-container.branded{top:0!important}body.ytcenter-branding-remove-background #guide-container.branded{background:none repeat scroll 0 0 transparent!important}.ytcenter-settings-content{color:#555}.ltr #sb-wrapper #sb-container{right:28px!important}.rtl #sb-wrapper #sb-container{left:28px!important}.ytcenter-embed{display:inline-block;vertical-align:top}.ytcenter-settings-header .yt-uix-button-epic-nav-item{border:0;padding:0 3px 3px 3px;cursor:pointer}.ytcenter-settings-header a.yt-uix-button.yt-uix-button-epic-nav-item,.ytcenter-settings-header button.yt-uix-button-epic-nav-item,.ytcenter-settings-header .epic-nav-item,.ytcenter-settings-header .epic-nav-item-heading{border:0;padding:0 3px 3px 3px;cursor:pointer;background:0;color:#9c9c9c;font-size:11px;font-weight:bold;height:29px;line-height:29px;-moz-box-sizing:content-box;-ms-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;-moz-border-radius:0;-webkit-border-radius:0;border-radius:0}.ytcenter-settings-header .yt-uix-button-epic-nav-item.selected{border-bottom:3px solid;border-color:#b00;padding-bottom:0;color:#333}.ytcenter-settings-header a.yt-uix-button-epic-nav-item:hover,.ytcenter-settings-header a.yt-uix-button-epic-nav-item.selected,.ytcenter-settings-header button.yt-uix-button-epic-nav-item:hover,.ytcenter-settings-header button.yt-uix-button-epic-nav-item.selected,.ytcenter-settings-header .epic-nav-item:hover,.ytcenter-settings-header .epic-nav-item.selected,.ytcenter-settings-header .epic-nav-item-heading{height:29px;line-height:29px;vertical-align:bottom;color:#333;border-bottom:3px solid;border-color:#b00;padding-bottom:0;display:inline-block}.ytcenter-lights-off #watch7-video,.ytcenter-lights-off #player-api,.ytcenter-lights-off #player-api-legacy,.ytcenter-lights-off #movie_player{z-index:200000!important}.ytcenter-lights-off #page-container{z-index:auto!important}.ytcenter-lights-off #guide{z-index:0!important}.ytcenter-lights-off #masthead-positioner{transform:none!important}.ytcenter-lights-off .ytcenter-lights-off-overlay{position:fixed;top:0;width:100%;height:100%;z-index:199999;-moz-transform:translateZ(0);-ms-transform:translateZ(0);-webkit-transform:translateZ(0);transform:translateZ(0)}.ltr.ytcenter-lights-off .ytcenter-lights-off-overlay{left:0}.rtl.ytcenter-lights-off .ytcenter-lights-off-overlay{right:0}.ytcenter-lights-off.ytcenter-lights-off-click-through .ytcenter-lights-off-overlay{pointer-events:none}.ytcenter-branding-remove-banner #watch7-branded-banner,.ytcenter-branding-remove-banner #player-branded-banner,.ytcenter-branding-remove-banner #player-branded-banner-legacy{display:none!important}.ytcenter-repeat-icon{background:no-repeat url(//s.ytimg.com/yts/imgbin/www-hitchhiker-vflMCg1ne.png) -19px -25px;width:30px;height:18px}#watch7-action-buttons .yt-uix-button-content{color:#555;text-shadow:0 1px 0 #fff}.ytcenter-uix-button-toggled{border-color:#c6c6c6!important;background-color:#e9e9e9!important;-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,.20)!important;-ms-box-shadow:inset 0 1px 1px rgba(0,0,0,.20)!important;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.20)!important;box-shadow:inset 0 1px 1px rgba(0,0,0,.20)!important;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#fff8f8f8,EndColorStr=#ffeeeeee)!important;background-image:-moz-linear-gradient(top,#f8f8f8 0,#eee 100%)!important;background-image:-ms-linear-gradient(top,#f8f8f8 0,#eee 100%)!important;background-image:-o-linear-gradient(top,#f8f8f8 0,#eee 100%)!important;background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#f8f8f8),color-stop(100%,#eee))!important;background-image:-webkit-linear-gradient(top,#f8f8f8 0,#eee 100%)!important;background-image:linear-gradient(to bottom,#f8f8f8 0,#eee 100%)!important}.ytcenter-align{padding:0!important};.ytcenter-align>#watch7-video{margin:0 auto!important}.ytcenter-fill,.ytcenter-fill #player-api,.ytcenter-fill #player-api-legacy{width:100%!important;height:100%!important}ul.ytcenter-menu-3d-hide li.ytcenter-menu-item-3d{display:none}.ytcenter-range{display:inline-block;cursor:default;position:relative;border:1px solid;outline:0;white-space:nowrap;word-wrap:normal;vertical-align:middle;-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;border-color:#CCC #CCC #AAA;background:white;padding:0;margin:0;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ytcenter-range a.ytcenter-range-handle{position:absolute;top:-1px;outline:0;cursor:default;padding:0;margin:0;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ltr .ytcenter-range a.ytcenter-range-handle{left:0;margin-left:-.5em}.rtl .ytcenter-range a.ytcenter-range-handle{right:0;margin-right:-.5em}.ytcenter-remove-ads-page .ad-div,.ytcenter-remove-ads-page .mastad,.ytcenter-remove-ads-page .lohp-pyv-shelf-container,.ytcenter-remove-ads-page .masthead-ad-control,.ytcenter-remove-ads-page .masthead-ad-control-lihp,.ytcenter-remove-ads-page .watch-pyv-vid,.ytcenter-remove-ads-page .branded-page-v2-top-row,.ytcenter-remove-ads-page .pyv-afc-ads-container,.ytcenter-remove-ads-page #feed-pyv-container,.ytcenter-remove-ads-page #premium-yva,.ytcenter-remove-ads-page #ad_creative_1,.ytcenter-remove-ads-page #watch-channel-brand-div{display:none!important}.ytcenter-remove-ads-page #content .branded-page-v2-has-top-row.branded-page-v2-container .branded-page-v2-top-row{display:block!important}.ytcenter-remove-ads-page .branded-page-v2-masthead-ad-header.masthead-ad-expanded .branded-page-v2-primary-col{border-top:0!important}#movie_player{overflow:hidden!important}#player,#player-api,#player-api-legacy,#movie_player,#movie_player *:focus{outline:0!important}.flex-width-enabled>* #page,.flex-width-enabled #guide+#content{max-width:1422px!important;min-width:1003px!important;width:auto!important}.flex-width-enabled #yt-admin.hh{width:100%!important}.ltr.ytcenter-site-center.flex-width-enabled #header{padding-left:0!important}.rtl.ytcenter-site-center.flex-width-enabled #header{padding-right:0!important}.flex-width-enabled #header #masthead-subnav,.flex-width-enabled #header #masthead-subnav ul{width:100%!important}body>#page{max-width:100%!important;width:auto!important}#watch7-creator-bar{position:relative;z-index:3}.video-list .video-response:first-child a{position:static!important}.video-list .video-response a{position:absolute}.watch7-playlist-bar{width:100%!important}.watch7-playlist-bar-right{width:auto!important}.ytcenter-intelligentfeed .shelf-wrapper,.ytcenter-intelligentfeed .feed-item-collapsed-container .feed-item-collapsed-items{display:none}.ytcenter-intelligentfeed .shelf-wrapper:first-child{display:block}.ytcenter-intelligentfeed.ytcenter-intelligentfeed-minimized .shelf-wrapper:first-child{max-height:378px}.ytcenter-intelligentfeed .feed-item-main-content .yt-uix-shelfslider-item{margin-bottom:10px;height:179px}.ltr .ytcenter-intelligentfeed .feed-item-main-content .yt-uix-shelfslider-item{float:left}.rtl .ytcenter-intelligentfeed .feed-item-main-content .yt-uix-shelfslider-item{float:right}.ytcenter-intelligentfeed .feed-item-main-content .shelf-wrapper{margin-bottom:0!important;overflow:hidden}.ytcenter-thumbnail-quality{position:absolute;vertical-align:middle;padding:2px 4px;line-height:14px;font-weight:bold;font-size:11px;zoom:1;border-radius:2px}.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-success,.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-loading,.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button,.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-pos-topleft .video-time,.ytcenter-thumbnail-quality-pos-topleft .ytcenter-thumbnail-quality,.ytcenter-thumbnail-ratingcount-pos-topleft .ytcenter-thumbnail-ratingcount{top:2px!important;left:2px!important;right:auto!important}.ltr .watched.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-success,.ltr .watched.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-loading,.ltr .watched.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button,.ltr .watched.ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-sign-in,.ltr .watched.ytcenter-thumbnail-timecode-pos-topleft .video-time,.ltr .watched.ytcenter-thumbnail-quality-pos-topleft .ytcenter-thumbnail-quality,.ltr .watched.ytcenter-thumbnail-ratingcount-pos-topleft .ytcenter-thumbnail-ratingcount{top:20px!important;left:2px!important;right:auto!important}.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-success,.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-loading,.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button,.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-pos-topright .video-time,.ytcenter-thumbnail-quality-pos-topright .ytcenter-thumbnail-quality,.ytcenter-thumbnail-ratingcount-pos-topright .ytcenter-thumbnail-ratingcount{top:2px!important;right:2px!important;left:auto!important}.rtl .watched.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-success,.rtl .watched.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-loading,.rtl .watched.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button,.rtl .watched.ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-sign-in,.rtl .watched.ytcenter-thumbnail-timecode-pos-topright .video-time,.rtl .watched.ytcenter-thumbnail-quality-pos-topright .ytcenter-thumbnail-quality,.rtl .watched.ytcenter-thumbnail-ratingcount-pos-topright .ytcenter-thumbnail-ratingcount{top:20px!important;right:2px!important;left:auto!important}.ytcenter-thumbnail-watchlater-pos-bottomleft .addto-watch-later-button-success,.ytcenter-thumbnail-watchlater-pos-bottomleft .addto-watch-later-button-loading,.ytcenter-thumbnail-watchlater-pos-bottomleft .addto-watch-later-button,.ytcenter-thumbnail-watchlater-pos-bottomleft .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-pos-bottomleft .video-time,.ytcenter-thumbnail-quality-pos-bottomleft .ytcenter-thumbnail-quality,.ytcenter-thumbnail-ratingcount-pos-bottomleft .ytcenter-thumbnail-ratingcount{bottom:2px!important;left:2px!important;right:auto!important}.ytcenter-thumbnail-watchlater-pos-bottomright .addto-watch-later-button-success,.ytcenter-thumbnail-watchlater-pos-bottomright .addto-watch-later-button-loading,.ytcenter-thumbnail-watchlater-pos-bottomright .addto-watch-later-button,.ytcenter-thumbnail-watchlater-pos-bottomright .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-pos-bottomright .video-time,.ytcenter-thumbnail-quality-pos-bottomright .ytcenter-thumbnail-quality,.ytcenter-thumbnail-ratingcount-pos-bottomright .ytcenter-thumbnail-ratingcount{bottom:2px!important;right:2px!important;left:auto!important}#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-watchlater-pos-topleft .addto-watch-later-button-sign-in,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-timecode-pos-topleft .video-time,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-quality-pos-topleft .ytcenter-thumbnail-quality,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-ratingcount-pos-topleft .ytcenter-thumbnail-ratingcount{top:30px!important}#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-watchlater-pos-topright .addto-watch-later-button-sign-in,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-timecode-pos-topright .video-time,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-quality-pos-topright .ytcenter-thumbnail-quality,#playlist-bar-lists-content .playlist-bar-item .ytcenter-thumbnail-ratingcount-pos-topright .ytcenter-thumbnail-ratingcount{top:30px!important}.ytcenter-thumbnail-watchlater-visible-always .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-hide_hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-always .addto-watch-later-button-sign-in,.ytcenter-thumbnail-watchlater-visible-hide_hover .addto-watch-later-button-sign-in{display:block!important;opacity:1!important}.ytcenter-thumbnail-timecode-visible-always .video-time,.ytcenter-thumbnail-timecode-visible-hide_hover .video-time{display:block!important;opacity:.75!important;filter:alpha(opacity=75)!important}.ytcenter-thumbnail-watchlater-visible-show_hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-never .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-show_hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-watchlater-visible-never .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-visible-show_hover .video-time,.ytcenter-thumbnail-timecode-visible-never .video-time,.ytcenter-thumbnail-watchlater-visible-hide_hover a:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-hide_hover a:hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-visible-hide_hover a:hover .video-time,.ytcenter-thumbnail-watchlater-visible-hide_hover div.thumb-wrapper:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-hide_hover div.thumb-wrapper:hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-visible-hide_hover div.thumb-wrapper:hover .video-time,.ytcenter-thumbnail-watchlater-visible-hide_hover div.yt-lockup-thumbnail:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-hide_hover div.yt-lockup-thumbnail:hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-timecode-visible-hide_hover div.yt-lockup-thumbnail:hover .video-time{display:none!important;opacity:0!important;filter:alpha(opacity=0)!important}.ytcenter-thumbnail-watchlater-visible-show_hover a:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-show_hover a:hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-watchlater-visible-show_hover div.thumb-wrapper:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-show_hover div.thumb-wrapper:hover .addto-watch-later-button-sign-in,.ytcenter-thumbnail-watchlater-visible-show_hover div.yt-lockup-thumbnail:hover .addto-watch-later-button,.ytcenter-thumbnail-watchlater-visible-show_hover div.yt-lockup-thumbnail:hover .addto-watch-later-button-sign-in{display:block!important;opacity:1!important;filter:alpha(opacity=100)!important}.ytcenter-thumbnail-timecode-visible-show_hover a:hover .video-time,.ytcenter-thumbnail-timecode-visible-show_hover div.thumb-wrapper:hover .video-time,.ytcenter-thumbnail-timecode-visible-show_hover div.yt-lockup-thumbnail:hover .video-time{display:block!important;opacity:.75!important;filter:alpha(opacity=75)!important}.ytcenter-placementsystem-activated .placementsystem-target{visibility:hidden}.ytcenter-placementsystem-activated .placementsystem-target::before{float:left;display:inline-block;content:' ';border-left:1px solid #ccc;height:28px;visibility:visible;position:absolute}#watch8-ytcenter-buttons{position:relative;margin:0 -10px}.ytcenter-placementsystem-activated #watch8-ytcenter-buttons>*,.ytcenter-placementsystem-activated #watch8-secondary-actions>*,.ytcenter-placementsystem-activated #watch8-sentiment-actions>*{display:inline-block;position:relative}.ytcenter-placementsystem-activated #watch7-sentiment-actions,.ytcenter-placementsystem-activated #watch7-ytcenter-buttons,.ytcenter-placementsystem-activated #watch8-sentiment-actions,.ytcenter-placementsystem-activated #watch8-secondary-actions,.ytcenter-placementsystem-activated #watch8-ytcenter-buttons{min-width:40px;min-height:28px}.ytcenter-guide-hidden #guide{display:none!important}.ytcenter-guide-hidden.ytcenter-site-center #watch7-main-container{padding:0!important}.ltr .ytcenter-intelligentfeed .yt-shelf-grid-item{margin-right:7px!important}.rtl .ytcenter-intelligentfeed .yt-shelf-grid-item{margin-left:7px!important}.ytcenter-ticker-hidden #ticker{display:none!important}.sitewide-ticker-visible.ytcenter-ticker-hidden #masthead-positioner-height-offset{height:90px!important}.appbar-hidden.ytcenter-ticker-hidden #masthead-positioner-height-offset{height:50px!important}.sitewide-ticker-visible.ytcenter-ticker-hidden #appbar-guide-menu{margin-top:50px!important}.watched-badge{display:none;top:2px!important}.ltr .watched-badge{left:2px!important}.rtl .watched-badge{right:2px!important}.watched .watched-badge{display:block}.ytcenter-hide-guide-count .guide-count{display:none!important}.ytcenter-hide-feed-item-action-menu #feed .feed-item-action-menu{display:none!important}.ytcenter-hide-recommended-channels .branded-page-v2-secondary-col{display:none!important}.ytcenter-hide-recommended-channels .branded-page-v2-col-container{width:100%!important}.ytcenter-hide-recommended-channels .watch-sidebar-section{margin:0!important}.site-center-aligned.ytcenter-hide-recommended-channels .browse-list-item-container:hover .compact-shelf .yt-uix-shelfslider-prev{left:-25px!important}.site-center-aligned.ytcenter-hide-recommended-channels .browse-list-item-container:hover .compact-shelf .yt-uix-shelfslider-next{right:-25px!important}.site-center-aligned.ytcenter-hide-recommended-channels .browse-list-item-container:hover .compact-shelf .yt-uix-button-shelf-slider-pager{width:25px!important}.ytcenter-hide-resume-playback-bar .resume-playback-background,.ytcenter-hide-resume-playback-bar .resume-playback-progress-bar{display:none}", | |
topbar: ".ytcenter-exp-topbar-static #masthead-positioner{position:relative;top:0}.ytcenter-lights-off #masthead-positioner{z-index:0}.ytcenter-exp-topbar-static #appbar-guide-menu{top:0!important;padding-top:90px!important}.site-center-aligned #page{margin:0 auto!important}@media screen and (min-width:1409px){.ltr.show-guide-if-wide.guide-pinned #page,.ltr.show-guide.guide-pinned #page{padding-left:230px!important}.rtl.show-guide-if-wide.guide-pinned #page,.rtl.show-guide.guide-pinned #page{padding-right:230px!important}}.site-as-giant-card .feed-item-main.legacy-style.ytcenter-intelligentfeed .feed-item-main-content{width:auto!important}.ltr.site-as-giant-card .feed-item-main.legacy-style .feed-item-main-content{width:auto!important;padding-right:40px!important}.rtl.site-as-giant-card .feed-item-main.legacy-style .feed-item-main-content{width:auto!important;padding-left:40px!important}.site-center-aligned #content #yt-admin{padding:0!important}", | |
flags: ".ytcenter-flag-unknown{border:0;width:16px;height:11px;background:url('') no-repeat center}.ytcenter-flag-button{border:0;width:16px;height:11px;background:url('') no-repeat center}.ytcenter-flag-button:hover{background:url('') no-repeat center}.ytcenter-flag-loading{width:13px!important;height:13px!important;background:url('') no-repeat center!important}.ytcenter-flag-ad{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ae{width:16px;height:11px;background-image:url('')}.ytcenter-flag-af{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ag{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ai{width:16px;height:11px;background-image:url('')}.ytcenter-flag-al{width:16px;height:11px;background-image:url('')}.ytcenter-flag-am{width:16px;height:11px;background-image:url('')}.ytcenter-flag-an{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ao{width:16px;height:11px;background-image:url('')}.ytcenter-flag-aq{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ar{width:16px;height:11px;background-image:url('')}.ytcenter-flag-as{width:16px;height:11px;background-image:url('')}.ytcenter-flag-at{width:16px;height:11px;background-image:url('')}.ytcenter-flag-au{width:16px;height:11px;background-image:url('')}.ytcenter-flag-aw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ax{width:16px;height:11px;background-image:url('')}.ytcenter-flag-az{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ba{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bb{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bd{width:16px;height:11px;background-image:url('')}.ytcenter-flag-be{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bi{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bj{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bo{width:16px;height:11px;background-image:url('')}.ytcenter-flag-br{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bs{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-by{width:16px;height:11px;background-image:url('')}.ytcenter-flag-bz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ca{width:16px;height:11px;background-image:url('')}.ytcenter-flag-catalonia{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cd{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ch{width:11px;height:11px;background-image:url('')}.ytcenter-flag-ci{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ck{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-co{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cs{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cx{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cy{width:16px;height:11px;background-image:url('')}.ytcenter-flag-cz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-de{width:16px;height:11px;background-image:url('')}.ytcenter-flag-dj{width:16px;height:11px;background-image:url('')}.ytcenter-flag-dk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-dm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-do{width:16px;height:11px;background-image:url('')}.ytcenter-flag-dz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ec{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ee{width:16px;height:11px;background-image:url('')}.ytcenter-flag-eg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-eh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-england{width:16px;height:11px;background-image:url('')}.ytcenter-flag-er{width:16px;height:11px;background-image:url('')}.ytcenter-flag-es{width:16px;height:11px;background-image:url('')}.ytcenter-flag-et{width:16px;height:11px;background-image:url('')}.ytcenter-flag-europeanunion{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fam{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fi{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fj{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fo{width:16px;height:11px;background-image:url('')}.ytcenter-flag-fr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ga{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gb{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gd{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ge{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gi{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gp{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gq{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gs{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-gy{width:16px;height:11px;background-image:url('')}.ytcenter-flag-hk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-hm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-hn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-hr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ht{width:16px;height:11px;background-image:url('')}.ytcenter-flag-hu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-id{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ie{width:16px;height:11px;background-image:url('')}.ytcenter-flag-il{width:16px;height:11px;background-image:url('')}.ytcenter-flag-in{width:16px;height:11px;background-image:url('')}.ytcenter-flag-io{width:16px;height:11px;background-image:url('')}.ytcenter-flag-iq{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ir{width:16px;height:11px;background-image:url('')}.ytcenter-flag-is{width:16px;height:11px;background-image:url('')}.ytcenter-flag-it{width:16px;height:11px;background-image:url('')}.ytcenter-flag-jm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-jo{width:16px;height:11px;background-image:url('')}.ytcenter-flag-jp{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ke{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ki{width:16px;height:11px;background-image:url('')}.ytcenter-flag-km{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kp{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ky{width:16px;height:11px;background-image:url('')}.ytcenter-flag-kz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-la{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lb{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-li{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ls{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-lv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ly{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ma{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-md{width:16px;height:11px;background-image:url('')}.ytcenter-flag-me{width:16px;height:12px;background-image:url('')}.ytcenter-flag-mg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ml{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mo{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mp{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mq{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ms{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mx{width:16px;height:11px;background-image:url('')}.ytcenter-flag-my{width:16px;height:11px;background-image:url('')}.ytcenter-flag-mz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-na{width:16px;height:11px;background-image:url('')}.ytcenter-flag-nc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ne{width:16px;height:11px;background-image:url('')}.ytcenter-flag-nf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ng{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ni{width:16px;height:11px;background-image:url('')}.ytcenter-flag-nl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-no{width:16px;height:11px;background-image:url('')}.ytcenter-flag-np{width:9px;height:11px;background-image:url('')}.ytcenter-flag-nr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-nu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-nz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-om{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pa{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pe{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ph{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ps{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-pw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-py{width:16px;height:11px;background-image:url('')}.ytcenter-flag-qa{width:16px;height:11px;background-image:url('')}.ytcenter-flag-re{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ro{width:16px;height:11px;background-image:url('')}.ytcenter-flag-rs{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ru{width:16px;height:11px;background-image:url('')}.ytcenter-flag-rw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sa{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sb{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-scotland{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sd{width:16px;height:11px;background-image:url('')}.ytcenter-flag-se{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sh{width:16px;height:11px;background-image:url('')}.ytcenter-flag-si{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sj{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-so{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-st{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sy{width:16px;height:11px;background-image:url('')}.ytcenter-flag-sz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-td{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-th{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tj{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tk{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tl{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-to{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tr{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tv{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tw{width:16px;height:11px;background-image:url('')}.ytcenter-flag-tz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ua{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ug{width:16px;height:11px;background-image:url('')}.ytcenter-flag-um{width:16px;height:11px;background-image:url('')}.ytcenter-flag-us{width:16px;height:11px;background-image:url('')}.ytcenter-flag-uy{width:16px;height:11px;background-image:url('')}.ytcenter-flag-uz{width:16px;height:11px;background-image:url('')}.ytcenter-flag-va{width:16px;height:11px;background-image:url('')}.ytcenter-flag-vc{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ve{width:16px;height:11px;background-image:url('')}.ytcenter-flag-vg{width:16px;height:11px;background-image:url('')}.ytcenter-flag-vi{width:16px;height:11px;background-image:url('')}.ytcenter-flag-vn{width:16px;height:11px;background-image:url('')}.ytcenter-flag-vu{width:16px;height:11px;background-image:url('')}.ytcenter-flag-wales{width:16px;height:11px;background-image:url('')}.ytcenter-flag-wf{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ws{width:16px;height:11px;background-image:url('')}.ytcenter-flag-ye{width:16px;height:11px;background-image:url('')}.ytcenter-flag-yt{width:16px;height:11px;background-image:url('')}.ytcenter-flag-za{width:16px;height:11px;background-image:url('')}.ytcenter-flag-zm{width:16px;height:11px;background-image:url('')}.ytcenter-flag-zw{width:16px;height:11px;background-image:url('')}.ytcenter-comments-blocked>*{display:none!important}.ytcenter-comments-blocked>*:first-child,.ytcenter-comments-blocked.Jx>*:first-child+div{display:block!important;font-weight:bold;color:#ccc}", | |
html5player: "body.ytcenter-hide-watch-later-on-player .ytp-button.ytp-button-watch-later{display:none!important}body.ytcenter-livestream #watch7-views-info{top:-27px!important}.html5-video-player.ytcenter-autohide-none .html5-video-container{bottom:35px!important}.html5-video-player.ytcenter-autohide-progressbar .html5-video-container{bottom:30px!important}.html5-video-player.ytcenter-autohide-controlbar .html5-video-container{bottom:3px!important}html[data-player-size=fullscreen] .html5-video-player.ytcenter-autohide-controlbar .html5-video-container,html[data-player-size=fullscreen] .html5-video-player.ytcenter-autohide-progressbar .html5-video-container,html[data-player-size=fullscreen] .html5-video-player.ytcenter-autohide-none .html5-video-container,html[data-player-size=fullscreen] .html5-video-player.ytcenter-autohide-both .html5-video-container{bottom:0!important}html[data-player-size=fullscreen] .ytp-user-idle.autominimize-progress-bar-fullscreenonly.playing-mode:not(.seeking-mode) .ytp-progress-bar-container:not(.ytp-block-autohide) .ytp-progress-list{-moz-transform:scaley(0.375);-ms-transform:scaley(0.375);-webkit-transform:scaley(0.375);transform:scaley(0.375);-moz-transition:-moz-transform .5s ease-in,background .15s;-webkit-transition:-webkit-transform .5s ease-in,background .15s;-ms-transition:-ms-transform .5s ease-in,background .15s;transition:transform .5s ease-in,background .15s}html[data-player-size=fullscreen] .ytp-user-idle.autominimize-progress-bar-fullscreenonly.playing-mode:not(.seeking-mode) .ytp-progress-bar-container:not(.ytp-block-autohide) .ytp-progress-list{-moz-transform:scaley(0.375);-ms-transform:scaley(0.375);-webkit-transform:scaley(0.375);transform:scaley(0.375);-moz-transition:-moz-transform .5s ease-in,background .15s;-webkit-transition:-webkit-transform .5s ease-in,background .15s;-ms-transition:-ms-transform .5s ease-in,background .15s;transition:transform .5s ease-in,background .15s}html[data-player-size=fullscreen] .ytp-user-idle.autominimize-progress-bar-fullscreenonly.playing-mode:not(.seeking-mode) .ytp-progress-bar-container:not(.ytp-block-autohide) .html5-scrubber-button{-moz-transform:translateY(2.5px) scale(0,0);-ms-transform:translateY(2.5px) scale(0,0);-webkit-transform:translateY(2.5px) scale(0,0);transform:translateY(2.5px) scale(0,0);-moz-transition:-moz-transform .5s ease-in;-webkit-transition:-webkit-transform .5s ease-in;-ms-transition:-ms-transform .5s ease-in;transition:transform .5s ease-in}html[data-player-size=fullscreen] .ytp-user-idle.autominimize-progress-bar-fullscreenonly.playing-mode:not(.seeking-mode) .ytp-progress-bar-container:not(.ytp-block-autohide) .html5-clip-marker{-moz-transform:scaleY(0.1875);-ms-transform:scaleY(0.1875);-webkit-transform:scaleY(0.1875);transform:scaleY(0.1875);-moz-transition:-moz-transform .5s ease-in;-webkit-transition:-webkit-transform .5s ease-in;-ms-transition:-ms-transform .5s ease-in;transition:transform .5s ease-in}.ytp-user-idle.autohide-controlbar.playing-mode:not(.seeking-mode) .html5-video-controls:not(.ytp-block-autohide),html[data-player-size=fullscreen] .ytp-user-idle.autohide-controlbar-fullscreenonly.playing-mode:not(.seeking-mode) .html5-video-controls:not(.ytp-block-autohide){-moz-transform:translatey(27px);-ms-transform:translatey(27px);-webkit-transform:translatey(27px);transform:translatey(27px);-moz-transition:-moz-transform .5s ease-in;-webkit-transition:-webkit-transform .5s ease-in;-ms-transition:-ms-transform .5s ease-in;transition:transform .5s ease-in}.white .html5-volume-slider-foreground:before,.white .html5-volume-slider-foreground:after{background:#bbb!important}.white .html5-volume-slider-foreground:after{background:#777!important}.ytp-force-transform{-webkit-transform:none!important}.ytcenter-disable-endscreen .html5-video-player .html5-endscreen{display:none!important}.ytcenter-disable-html5 #movie_player.html5-video-player,.ytcenter-disable-html5 #player-unavailable{display:none!important}body.ytcenter-scrolled-top .html5-video-player.playlist-created .ytp-button.ytp-button-playlist,body.ytcenter-scrolled-top .html5-video-player.playlist-created .ytp-button.ytp-button-prev,body.ytcenter-scrolled-top .html5-video-player.playlist-created .ytp-button.ytp-button-next,body.ytcenter-scrolled-top .html5-video-player.playlist-created.playlist-loaded .ytp-playlist-tray-container{display:block}", | |
gridview: ".ytcenter-gridview .shelf-item .shelf-title-table{position:absolute;right:0;width:auto}.ytcenter-gridview .shelf-item .shelf-title-table .shelf-title-row .menu-container{left:0!important}.ytcenter-grid-subscriptions-username,.ytcenter-gridview #browse-items-primary .branded-page-module-title{display:none}.ytcenter-gridview .ytcenter-grid-subscriptions-username{display:block}.ytcenter-gridview .branded-page-v2-secondary-col,.ytcenter-gridview .feed-item-container .feed-author-bubble-container{display:none!important}.ytcenter-gridview ul.feed-list{margin:0 auto}.ytcenter-gridview .feed-item-container .menu-container{z-index:1}.ytcenter-gridview.cardified-page .feed-item-dismissable{padding:3px}.ltr.ytcenter-gridview.cardified-page .yt-lockup-thumbnail,.ltr.ytcenter-gridview.cardified-page .feed-item-action-menu{margin-left:-3px;margin-top:-3px}.rtl.ytcenter-gridview.cardified-page .yt-lockup-thumbnail,.rtl.ytcenter-gridview.cardified-page .feed-item-action-menu{margin-right:-3px;margin-top:-3px}.ytcenter-gridview .feed-item-container{padding:0!important;width:196px!important;border:0!important}.ytcenter-gridview .feed-item-container,.ytcenter-gridview .feed-item-container .yt-lockup-thumbnail{width:196px!important}.ytcenter-gridview .expanded-shelf-content-list,.ytcenter-gridview .expanded-shelf-content-item{margin-bottom:0!important;margin-right:0!important}.ytcenter-gridview #browse-items-primary{padding:15px;margin-right:-15px;font-size:0}.ytcenter-gridview .feed-item-container{display:inline-block;margin-right:10px!important;margin-bottom:20px!important;vertical-align:top}.ytcenter-gridview #browse-items-primary .section-list>li{float:left;height:229px;overflow:hidden}.ytcenter-gridview .feed-item-container .yt-lockup-thumbnail{float:none!important}.ytcenter-gridview .feed-item-header{display:none!important;position:absolute!important;top:110px!important}.ytcenter-gridview .ytcenter-gridview-username{margin-bottom:5px}.ytcenter-gridview .feed-item-header .feed-item-time{display:none!important}.ltr.ytcenter-gridview .feed-item-action-menu{top:8px!important;right:0!important}.rtl.ytcenter-gridview .feed-item-action-menu{top:8px!important;left:0!important}.ytcenter-gridview .yt-lockup-meta{margin:0!important}.ytcenter-gridview .feed-item-container .feed-item-main{margin:0!important;border:0!important}.ltr.ytcenter-gridview .feed-item-container .feed-item-main .yt-lockup-content{float:left!important;width:100%!important}.rtl.ytcenter-gridview .feed-item-container .feed-item-main .yt-lockup-content{float:right!important;width:100%!important}.ytcenter-gridview .yt-lockup-badges,.ytcenter-hide-watched-videos .ytcenter-video-watched-wrapper{display:none!important}.ytcenter-gridview .feed-load-more-container,.ytcenter-gridview .feed-page .feed-list-item:last-child::after{clear:both}.ytcenter-gridview .feed-page .feed-list-item:last-child::before,.ytcenter-gridview .feed-page .feed-list-item:last-child::after{content:'.';display:block;height:0;visibility:hidden}.ytcenter-gridview .ytcenter-grid-subscriptions-username .yt-channel-title-icon-verified{margin-left:3px}", | |
images: ".ytcenter-image-welcome-settings{background:url('') no-repeat;width:647px;height:311px}.ytcenter-image-welcome-settings-repeater{background:url('') repeat-x;height:311px}", | |
dialog: ".ytcenter-dialog-base{position:fixed;top:0;width:100%;height:100%;text-align:center;z-index:2000000003;overflow:auto;-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none}.ltr .ytcenter-dialog-base{left:0}.rtl .ytcenter-dialog-base{right:0}.ytcenter-dialog-fg{position:relative;background:#fff;vertical-align:middle;z-index:2000000002;-moz-box-shadow:0 0 15px rgba(0,0,0,.18);-ms-box-shadow:0 0 15px rgba(0,0,0,.18);-webkit-box-shadow:0 0 15px rgba(0,0,0,.18);box-shadow:0 0 15px rgba(0,0,0,.18);display:inline-block;zoom:1;-moz-user-select:text;-ms-user-select:text;-webkit-user-select:text}.ltr .ytcenter-dialog-fg{text-align:left}.rtl .ytcenter-dialog-fg{text-align:right}.ytcenter-dialog-align,.ytcenter-dialog-fg{vertical-align:middle;display:inline-block}.ytcenter-dialog-align{height:100%}.ytcenter-dialog-fg{border:1px solid #e2e2e2}.ytcenter-dialog-bg{position:absolute;top:0;width:100%;min-width:970px;border:0;z-index:2000000001;background-color:#fff;opacity:.8;filter:alpha(opacity=80)}.ltr .ytcenter-dialog-bg{left:0}.rtl .ytcenter-dialog-bg{right:0}.ytcenter-dialog-base .ytcenter-dialog-header{border-bottom:1px solid #e2e2e2;height:60px;margin:0 -20px 20px}.ytcenter-dialog-base .ytcenter-dialog-header h2{font-weight:400;border-bottom:0;color:#555;overflow:hidden;white-space:nowrap;word-wrap:normal;zoom:1;-o-text-overflow:ellipsis;text-overflow:ellipsis;margin:0;padding:0 20px}.ytcenter-dialog-footer{clear:both;padding-top:20px;text-align:right}.ytcenter-dialog-fg-content{overflow:hidden;color:#333;padding:0 20px 20px}.ytcenter-dialog-fg-content h2{border-bottom:1px solid #ccc;color:#333;font-weight:700;font-size:20px;line-height:60px;overflow:hidden;white-space:nowrap;word-wrap:normal;zoom:1;-o-text-overflow:ellipsis;text-overflow:ellipsis;margin:0 -20px 20px;padding:0 20px}.ytcenter-dialog-show-content .ytcenter-dialog-content{display:block}body.ytcenter-dialog-active{height:100%;overflow:hidden}.ltr .ytcenter-dialog-footer button{margin-left:10px}.rtl .ytcenter-dialog-footer button{margin-right:10px}.ytcenter-dialog .ytcenter-settings-content h2{border-bottom:inherit!important;margin:inherit!important;padding:inherit!important;color:inherit!important;font-size:inherit!important;line-height:inherit!important;overflow:inherit!important;white-space:inherit!important;word-wrap:inherit!important;-o-text-overflow:inherit!important;text-overflow:inherit!important}", | |
scrollbar: ".ytcenter-scrollbar{overflow:hidden}.ytcenter-scrollbar:hover{overflow:auto}.ytcenter-scrollbar::-webkit-scrollbar{height:16px;overflow:visible;width:16px}.ytcenter-scrollbar::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,.2);background-clip:padding-box;border:solid transparent;border-width:1px 1px 1px 6px;min-height:28px;padding:100px 0 0;box-shadow:inset 1px 1px 0 rgba(0,0,0,.1),inset 0 -1px 0 rgba(0,0,0,.07)}.ytcenter-scrollbar::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.4);box-shadow:inset 1px 1px 1px rgba(0,0,0,.25)}.ytcenter-scrollbar::-webkit-scrollbar-thumb:active{background-color:rgba(0,0,0,0.5);box-shadow:inset 1px 1px 3px rgba(0,0,0,0.35)}.ytcenter-scrollbar::-webkit-scrollbar-corner{background:transparent}.ytcenter-scrollbar::-webkit-scrollbar-button{height:0;width:0}.ytcenter-scrollbar::-webkit-scrollbar-track{background-clip:padding-box;border:solid transparent;border-width:0 0 0 4px}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal{border-width:4px 0 0}.ytcenter-scrollbar::-webkit-scrollbar-track:hover{background-color:rgba(0,0,0,.05);box-shadow:inset 1px 0 0 rgba(0,0,0,.1)}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal:hover{box-shadow:inset 0 1px 0 rgba(0,0,0,.1)}.ytcenter-scrollbar::-webkit-scrollbar-track:active{background-color:rgba(0,0,0,.05);box-shadow:inset 1px 0 0 rgba(0,0,0,.14),inset -1px 0 0 rgba(0,0,0,.07)}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal:active{box-shadow:inset 0 1px 0 rgba(0,0,0,.14),inset 0 -1px 0 rgba(0,0,0,.07)}", | |
list: ".ytcenter-list{background:#fbfbfb;width:100%;height:100%;padding:0;margin:0}.ytcenter-list.ytcenter-dragdrop-indragging,.ytcenter-list.ytcenter-dragdrop-indragging *{cursor:move!important}.ytcenter-list-item:first-of-type{border-top-color:transparent}.ytcenter-list-item{position:relative;clear:both;margin:0;border-top:1px solid #fff;border-bottom:1px solid #e3e3e3;font-size:13px;width:100%;height:40px}.ytcenter-list-item .ytcenter-dragdrop-handle{width:20px;height:40px;cursor:move;position:absolute}.ltr .ytcenter-list-item .ytcenter-dragdrop-handle{left:0}.rtl .ytcenter-list-item .ytcenter-dragdrop-handle{left:0}.ytcenter-list-item.ytcenter-dragdrop-dragging{background:#f2f2f2}.ytcenter-list-item.ytcenter-dragdrop-dragging li{background:0}.ytcenter-list-item.ytcenter-dragdrop-dragging .ytcenter-dragdrop-handle{background:url(//s.ytimg.com/yts/img/playlist/drag-drop-indicator-vflv1iR5Z.png) 10px 15px no-repeat}.ytcenter-list.ytcenter-dragdrop-notdragging .ytcenter-list-item:hover .ytcenter-dragdrop-handle{background:url(//s.ytimg.com/yts/img/playlist/drag-drop-indicator-vflv1iR5Z.png) 10px 15px no-repeat}.ltr .ytcenter-list-item .ytcenter-list-item-content{padding:8px 13px 0 20px}.rtl .ytcenter-list-item .ytcenter-list-item-content{padding:8px 20px 0 13px}.ytcenter-list:hover .ytcenter-list-item{width:auto}.ytcenter-list-item .ytcenter-list-item-title{color:#000;font-weight:bold;font-size:13px}.ytcenter-list-item .ytcenter-list-item-subtext{display:block;font-size:11px;color:#777;line-height:1.4em;height:1.4em}.ytcenter-list-item-title,.ytcenter-list-item-subtext{text-overflow:ellipsis;-o-text-overflow:ellipsis;word-wrap:normal;white-space:nowrap;overflow:hidden}.ytcenter-list-item.ytcenter-list-item-selected{border-color:#e6e6e6;background:#e6e6e6!important}.ytcenter-list.ytcenter-dragdrop-notdragging .ytcenter-list-item:hover{background:#f2f2f2;cursor:pointer}.ytcenter-list-header-btn{min-width:172px!important;height:100%!important;border:0!important;border-radius:0!important;background:#fff!important;color:#000!important;text-shadow:0 0 0!important;overflow:hidden!important;position:relative!important}.ltr .ytcenter-list-header-btn{border-right:1px solid #eee!important}.rtl .ytcenter-list-header-btn{border-left:1px solid #eee!important}.ytcenter-list-header-btn:hover{background:0;border:0;padding-top:1px}.ytcenter-list-header-btn:hover:before{position:absolute;top:0;left:0;right:0;bottom:0;height:200px;content:' ';-moz-box-shadow:inset 0 0 5px #bbb;-ms-box-shadow:inset 0 0 5px #bbb;-webkit-box-shadow:inset 0 0 5px #bbb;box-shadow:inset 0 0 5px #bbb;background:transparent}", | |
confirmbox: ".ytcenter-confirmbox{position:fixed;top:0;width:100%;height:100%;z-index:9999}.ltr .ytcenter-confirmbox{left:0}.rtl .ytcenter-confirmbox{right:0}.ytcenter-confirmbox .ytcenter-confirmbox-mask{opacity:.95;filter:alpha(opacity=95);background:#000}.ytcenter-confirmbox .ytcenter-confirmbox-floater{height:50%;margin-bottom:-59px}.ltr .ytcenter-confirmbox .ytcenter-confirmbox-floater{float:left}.rtl .ytcenter-confirmbox .ytcenter-confirmbox-floater{float:right}.ytcenter-confirmbox .ytcenter-confirmbox-box{width:350px;height:90px;position:relative;background:#fff;z-index:10000;padding:14px;clear:both;margin:0 auto;border:1px solid #bbb;-moz-box-shadow:0 0 5px #bbb;-ms-box-shadow:0 0 5px #bbb;-webkit-box-shadow:0 0 5px #bbb;box-shadow:0 0 5px #bbb}.ytcenter-confirmbox .ytcenter-confirmbox-message{height:100%}.ytcenter-confirmbox .ytcenter-confirmbox-controls{margin-top:-28px}", | |
panel: ".ytcenter-panel{display:inline-block;width:773px;position:relative}.ltr .ytcenter-panel{border-left:1px solid #eee}.rtl .ytcenter-panel{border-right:1px solid #eee}.ytcenter-panel-label:first-of-type{padding-top:16px}.ytcenter-panel-label{padding:8px;color:#000;font-size:13px}.ytcenter-panel-label label{padding-right:8px;width:100px;display:inline-block}.ltr .ytcenter-panel-label label{padding-right:8px}.rtl .ytcenter-panel-label label{padding-left:8px}", | |
resizePanel: ".ytcenter-resize-panel{border:1px solid #eee;border-bottom:0;width:100%;margin-top:5px;line-height:normal}.ltr .ytcenter-resize-panel{border-left:0}.rtl .ytcenter-resize-panel{border-right:0}.ytcenter-resize-panel-header{width:100%;height:34px;border-left:1px solid #eee}.ltr .ytcenter-resize-panel-header{border-left:1px solid #eee}.rtl .ytcenter-resize-panel-header{border-right:1px solid #eee}.ytcenter-resize-panel-content{border-bottom:1px solid #eee;position:relative;overflow:hidden}.ytcenter-resize-panel-right>*{width:100%!important}.ytcenter-resize-panel-right>*:before{position:absolute;top:0;width:100%;height:1000%;content:' ';-moz-box-shadow:inset 0 0 5px #bbb;-ms-box-shadow:inset 0 0 5px #bbb;-webkit-box-shadow:inset 0 0 5px #bbb;box-shadow:inset 0 0 5px #bbb;background:transparent}.ltr .ytcenter-resize-panel-right>*:before{right:0}.rtl .ytcenter-resize-panel-right>*:before{right:0}.ytcenter-resize-panel-list{width:171px;height:301px;display:inline-block;border-top:1px solid #eee}.ltr .ytcenter-resize-panel-list{float:left;border-left:1px solid #eee}.rtl .ytcenter-resize-panel-list{float:right;border-right:1px solid #eee}.ytcenter-resize-dropdown-selected{background:#555!important;color:#fff!important}.ltr .ytcenter-resize-aspect-bind{display:inline-block;width:5px;height:52px;border-top:2px solid #aaa;border-right:2px solid #aaa;border-bottom:2px solid #aaa}.rtl .ytcenter-resize-aspect-bind{display:inline-block;width:5px;height:52px;border-top:2px solid #aaa;border-left:2px solid #aaa;border-bottom:2px solid #aaa}.ytcenter-resize-chain{width:7px;height:30px;background:url() no-repeat;background-color:#fff;background-position:center}.ytcenter-resize-unchain{width:7px;height:30px;background:url() no-repeat;background-color:#fff;background-position:center}.rtl .ytcenter-resize-chain,.rtl .ytcenter-resize-unchain{margin-left:0!important}.ytcenter-resize-ratio{cursor:pointer}.resize-options{padding:0 10px;position:absolute;bottom:-35px;left:0;right:0}.ytcenter-resize-panel-right{position:absolute;top:0;left:0;right:0}.ltr .ytcenter-resize-panel-right{margin-left:171px}.rtl .ytcenter-resize-panel-right{margin-right:171px}.ytcenter-resize-panel-right>*>*{position:relative;height:100%;padding-left:5px;margin-bottom:40px}.ytcenter-resize-panel .ytcenter-panel-label label{width:160px}.resize-options-right{min-width:60px}.ltr .resize-options-right{float:right;margin-left:10px}.rtl .resize-options-right{float:left;margin-right:10px}.resize-options-left{min-width:60px}.ltr .resize-options-left{float:left;margin-right:10px}.rtl .resize-options-left{float:right;margin-left:10px}", | |
modules: ".ytcenter-module-container{display:inline-block;vertical-align:middle}.ytcenter-modules-rangetext{width:65px;vertical-align:middle;border:1px solid #ccc}.ltr .ytcenter-modules-rangetext{margin-left:4px}.rtl .ytcenter-modules-rangetext{margin-right:4px}.ytcenter-colorpicker-presets{margin-top:10px}.ytcenter-colorpicker-presets-color{display:inline-block;width:20px;height:29px;cursor:pointer;border:1px solid #eee}.ltr .ytcenter-colorpicker-presets-color{float:left;margin-right:5px}.rtl .ytcenter-colorpicker-presets-color{float:right;margin-left:5px}.ytcenter-colorpicker-presets-label{display:block}.ytcenter-modules-colorpicker-huewrapper{width:250px;height:225px;display:inline-block}.ytcenter-modules-colorpickerfield-hue{width:225px;height:225px;display:inline-block;border:0}.ytcenter-modules-huerange{display:inline-block;border:0}.ytcenter-modules-htmlcolor>*:first-child{width:80px}.ytcenter-modules-currentcolor{display:inline-block;width:20px;height:29px}.ltr .ytcenter-modules-currentcolor{float:left}.rtl .ytcenter-modules-currentcolor{float:right}.ytcenter-modules-rgbwrapper{display:inline-block;vertical-align:top;width:225px;height:225px;position:relative}.ytcenter-modules-hwrapper .ytcenter-modules-htmlcolorlabel+input{width:auto!important}.ytcenter-modules-cpwrapper{width:475px;position:relative;z-index:4}.ytcenter-modules-hue{position:absolute!important;top:0!important;background:-moz-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-ms-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-o-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:-webkit-gradient(linear,left top,left bottom,from(#f00),color-stop(0.17,#ff0),color-stop(0.33,#0f0),color-stop(0.5,#0ff),color-stop(0.67,#00f),color-stop(0.83,#f0f),to(#f00))!important;background:-webkit-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important;background:linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)!important}.ytcenter-modules-hue .ie-1{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000',endColorstr='#ffff00')}.ytcenter-modules-hue .ie-2{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00',endColorstr='#00ff00')}.ytcenter-modules-hue .ie-3{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00',endColorstr='#00ffff')}.ytcenter-modules-hue .ie-4{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff',endColorstr='#0000ff')}.ytcenter-modules-hue .ie-5{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff',endColorstr='#ff00ff')}.ytcenter-modules-hue .ie-6{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff',endColorstr='#ff0000')}.ytcenter-modules-range{position:relative;display:inline-block;overflow:hidden;border:1px solid #eee;outline:0;-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;vertical-align:middle}.ytcenter-modules-range .ytcenter-modules-range-handle{border-width:1px;border-style:solid;outline:0;font-weight:bold;font-size:11px;white-space:nowrap;word-wrap:normal;vertical-align:middle;border-top:0;border-bottom:0}.ytcenter-modules-hue.ytcenter-modules-range{border-color:#000}.ytcenter-modules-hue.ytcenter-range .ytcenter-modules-range-handle{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px}.ytcenter-modules-range.ytcenter-hue .ytcenter-modules-range-handle{border:0!important;-moz-border-radius:0!important;-webkit-border-radius:0!important;border-radius:0!important}.ytcenter-modules-range.ytcenter-modules-hue{border:0!important;outline:0;overflow:visible;-moz-border-radius:0!important;-webkit-border-radius:0!important;border-radius:0!important}.ytcenter-modules-range-handle{position:absolute;top:0;cursor:default!important;margin:0;padding:0;text-shadow:0 1px 0 rgba(255,255,255,.5);border-color:#d3d3d3;background-color:#f8f8f8;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#fffcfcfc,EndColorStr=#fff8f8f8);background-image:-moz-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-ms-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-o-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#fcfcfc),color-stop(100%,#f8f8f8));background-image:-webkit-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:linear-gradient(to bottom,#fcfcfc 0,#f8f8f8 100%)}.rtl .ytcenter-modules-range-handle{left:-1px!important}.ytcenter-modules-range-handle .ytcenter-modules-range-handle-left{position:absolute;top:-7px;width:0;height:0;border:solid transparent;border-width:7px}.ytcenter-modules-range-handle .ytcenter-modules-range-handle-right{position:absolute;top:-7px;width:0;height:0;border:solid transparent;border-width:7px}.ltr .ytcenter-modules-range-handle .ytcenter-modules-range-handle-right,.ltr .ytcenter-modules-range-handle .ytcenter-modules-range-handle-left{left:7px;border-right-color:#fff}.rtl .ytcenter-modules-range-handle .ytcenter-modules-range-handle-right,.rtl .ytcenter-modules-range-handle .ytcenter-modules-range-handle-left{right:-7px;border-left-color:#fff}.ytcenter-modules-range.ytcenter-modules-hue .ytcenter-modules-range-handle .ytcenter-modules-range-handle-right{border-top:7px solid transparent!important;border-bottom:7px solid transparent!important}.ltr .ytcenter-modules-range.ytcenter-modules-hue .ytcenter-modules-range-handle .ytcenter-modules-range-handle-right{border-right:7px solid #000!important}.rtl .ytcenter-modules-range.ytcenter-modules-hue .ytcenter-modules-range-handle .ytcenter-modules-range-handle-right{border-left:7px solid #000!important}.ytcenter-modules-colorpicker{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;display:inline-block;width:16px;height:16px;cursor:pointer;border:1px solid #eee}.ytcenter-modules-colorpicker-saturation{position:absolute;width:100%;height:100%;top:0;background-image:-webkit-gradient(linear,0 0,100% 0,from(#FFF),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(left,#FFF,rgba(204,154,129,0));background-image:-moz-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-o-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-ms-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:linear-gradient(to right,#fff,rgba(204,154,129,0));-ms-filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1,startColorstr='#FFFFFFFF, endColorstr=#00CC9A81');filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1,startColorstr='#FFFFFFFF',endColorstr='#00CC9A81')}.ytcenter-modules-colorpicker-value{position:absolute;width:100%;height:100%;top:0;background-image:-webkit-gradient(linear,0 100%,0 0,from(#000),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-moz-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-o-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-ms-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:linear-gradient(to top,#000,rgba(204,154,129,0));-ms-filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81, endColorstr=#FF000000');filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81',endColorstr='#FF000000')}.ltr .ytcenter-modules-colorpicker-value,.ltr .ytcenter-modules-colorpicker-saturation{left:0}.rtl .ytcenter-modules-colorpicker-value,.rtl .ytcenter-modules-colorpicker-saturation{right:0}.ltr .ytcenter-modules-colorpicker-handler{position:absolute;top:0;left:0;-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px;width:5px;height:5px;border:1px solid #fff;background:#000}.rtl .ytcenter-modules-colorpicker-handler{position:absolute;top:0;right:0;-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px;width:5px;height:5px;border:1px solid #fff;background:#000}.ytcenter-scrollbar{overflow:hidden}.ytcenter-scrollbar:hover{overflow:auto}.ytcenter-scrollbar::-webkit-scrollbar{height:16px;overflow:visible;width:16px}.ytcenter-scrollbar::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,.2);background-clip:padding-box;border:solid transparent;border-width:1px 1px 1px 6px;min-height:28px;padding:100px 0 0;box-shadow:inset 1px 1px 0 rgba(0,0,0,.1),inset 0 -1px 0 rgba(0,0,0,.07)}.ytcenter-scrollbar::-webkit-scrollbar-thumb:hover{background-color:rgba(0,0,0,.4);box-shadow:inset 1px 1px 1px rgba(0,0,0,.25)}.ytcenter-scrollbar::-webkit-scrollbar-thumb:active{background-color:rgba(0,0,0,0.5);box-shadow:inset 1px 1px 3px rgba(0,0,0,0.35)}.ytcenter-scrollbar::-webkit-scrollbar-corner{background:transparent}.ytcenter-scrollbar::-webkit-scrollbar-button{height:0;width:0}.ytcenter-scrollbar::-webkit-scrollbar-track{background-clip:padding-box;border:solid transparent;border-width:0 0 0 4px}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal{border-width:4px 0 0}.ytcenter-scrollbar::-webkit-scrollbar-track:hover{background-color:rgba(0,0,0,.05);box-shadow:inset 1px 0 0 rgba(0,0,0,.1)}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal:hover{box-shadow:inset 0 1px 0 rgba(0,0,0,.1)}.ytcenter-scrollbar::-webkit-scrollbar-track:active{background-color:rgba(0,0,0,.05);box-shadow:inset 1px 0 0 rgba(0,0,0,.14),inset -1px 0 0 rgba(0,0,0,.07)}.ytcenter-scrollbar::-webkit-scrollbar-track:horizontal:active{box-shadow:inset 0 1px 0 rgba(0,0,0,.14),inset 0 -1px 0 rgba(0,0,0,.07)}.ltr .ytcenter-confirmbox{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999}.rtl .ytcenter-confirmbox{position:fixed;top:0;right:0;width:100%;height:100%;z-index:9999}.ytcenter-confirmbox .ytcenter-confirmbox-mask{opacity:.95;filter:alpha(opacity=95);background:#000}.ltr .ytcenter-confirmbox .ytcenter-confirmbox-floater{float:left;height:50%;margin-bottom:-59px}.rtl .ytcenter-confirmbox .ytcenter-confirmbox-floater{float:right;height:50%;margin-bottom:-59px}.ytcenter-confirmbox .ytcenter-confirmbox-box{width:350px;height:90px;position:relative;background:#fff;z-index:10000;padding:14px;clear:both;margin:0 auto;border:1px solid #bbb;-moz-box-shadow:0 0 5px #bbb;-ms-box-shadow:0 0 5px #bbb;-webkit-box-shadow:0 0 5px #bbb;box-shadow:0 0 5px #bbb}.ytcenter-confirmbox .ytcenter-confirmbox-message{height:100%}.ytcenter-confirmbox .ytcenter-confirmbox-controls{margin-top:-28px}.ytcenter-modules-hwrapper{margin-top:10px}.ytcenter-modules-htmlcolorlabel{display:block;vertical-align:middle}.ytcenter-modules-range{display:inline-block;cursor:default;position:relative;border:1px solid;outline:0;white-space:nowrap;word-wrap:normal;vertical-align:middle;-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;border-color:#CCC #CCC #AAA;background:white;padding:0;margin:0;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ytcenter-modules-range a.ytcenter-modules-range-handle{position:absolute;top:-1px;left:0;outline:0;margin-left:-.5em;cursor:default;padding:0;margin:0;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.rtl .ytcenter-modules-layoutExperiments{text-align:right}.ltr .ytcenter-modules-layoutExperiments{text-align:left}.ytcenter-modules-layoutExperiments ul.layoutExperimentList>li.empty{border-bottom:0!important;min-height:0!important}.ytcenter-modules-layoutExperiments ul.layoutExperimentList{margin-top:10px}.ytcenter-modules-layoutExperiments ul.layoutExperimentList>li{min-height:100px;padding:10px;border-bottom:1px solid #eee}.ytcenter-modules-layoutExperiments ul.layoutExperimentList>li:first-child{border-top:1px solid #eee}.ytcenter-modules-layoutExperiments .layoutExperimentDescription,.ytcenter-modules-layoutExperiments .layoutExperimentFeatures{padding-top:10px}.ytcenter-modules-layoutExperiments .layoutExperimentDescription span{display:block;padding-top:2px}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentFeaturesList>li{padding:2px 0 2px 10px}.rtl .ytcenter-modules-layoutExperiments .layoutExperimentFeaturesList>li{padding:2px 10px 2px 0}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentCodes{text-align:right;position:absolute;bottom:0;right:0}.rtl .ytcenter-modules-layoutExperiments .layoutExperimentCodes{text-align:left;position:absolute;bottom:0;left:0}.ytcenter-modules-layoutExperiments .layoutExperimentScreenshots{padding-top:5px;font-style:italic}.ytcenter-modules-layoutExperiments .layoutExperimentScreenshots a{margin:0 5px}.ytcenter-modules-layoutExperiments .layoutExperimentPreview{width:150px;height:150px;overflow:hidden}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentPreview{float:left}.rtl .ytcenter-modules-layoutExperiments .layoutExperimentPreview{float:right}.ytcenter-modules-layoutExperiments .layoutExperimentPreview img{height:100%}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentContent{position:relative;margin-left:160px;min-height:150px}.rtl .ytcenter-modules-layoutExperiments .layoutExperimentContent{position:relative;margin-right:160px;min-height:150px}.ytcenter-modules-layoutExperiments .layoutExperimentPad{padding-bottom:40px}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentsHeaderUpdateListButton,.rtl .ytcenter-modules-layoutExperiments .layoutExperimentsHeaderSetCodeButton{float:right}.ltr .ytcenter-modules-layoutExperiments .layoutExperimentsHeaderSetCodeButton,.rtl .ytcenter-modules-layoutExperiments .layoutExperimentsHeaderUpdateListButton{float:left}.ltr .ytcenter-arrow-fix{margin-left:-10px}.rtl .ytcenter-arrow-fix{margin-right:-10px}.ltr .ytcenter-button-fix{text-align:left}.rtl .ytcenter-button-fix{text-align:right}.ltr .ytcenter-modules-links{margin-left:20px}.rtl .ytcenter-modules-links{margin-right:20px}", | |
settings: ".yt-valign{white-space:nowrap}.yt-valign:before{content:'';height:100%}.yt-valign:before,.yt-valign-container{vertical-align:middle;display:inline-block}.clearfix:before{content:'.';display:block;height:0;visibility:hidden}.clearfix:after{content:'.';display:block;height:0;visibility:hidden;clear:both}.ytcenter-alert{position:relative;margin:5px 0;padding:0;overflow:hidden}.ytcenter-alert .close{margin:6px;border:0;overflow:hidden;cursor:pointer;background:no-repeat url();width:22px;height:22px!important}.ytcenter-alert .close:hover{background-color:rgba(0,0,0,.15);border-radius:3px}.ytcenter-settings-close-button{position:absolute!important;top:0!important;margin:0!important}.ltr .ytcenter-settings-close-button{right:0}.rtl .ytcenter-settings-close-button{left:0}.ytcenter-settings-category-list{width:100%}.ytcenter-settings-category-list .ytcenter-settings-category-item{display:block;position:relative;border:0;height:24px;background:0;color:#555;font-size:11px;text-decoration:none;overflow:hidden}.ytcenter-settings-category-list .ytcenter-settings-category-item:hover{background:#444;color:#fff}.ytcenter-settings-category-list .ytcenter-settings-category-item.ytcenter-selected{background:#cc181e;color:#fff;font-weight:bold;text-shadow:-1px -1px 0 rgba(0,0,0,0.25)}.ytcenter-settings-category-list .ytcenter-settings-category-item .yt-valign-container{padding:0 24px}#ytcenter-settings .ytcenter-dialog-fg{min-width:1003px}#ytcenter-settings .ytcenter-dialog-content{margin:0 -20px -20px -20px}.ytcenter-settings-content{display:table;width:100%}.ytcenter-settings-panel-left{position:relative;display:table-cell;padding-bottom:30px;min-width:190px;width:190px}.ltr .ytcenter-settings-panel-left{border-right:1px solid #e2e2e2}.rtl .ytcenter-settings-panel-left{border-left:1px solid #e2e2e2}.ytcenter-settings-panel-right-content{width:100%}.ltr .ytcenter-settings-subcat-header li{float:left;margin-left:13px}.rtl .ytcenter-settings-subcat-header li{float:right;margin-right:13px}.ytcenter-settings-subcat-header-wrapper{padding-top:4px}.ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item{border:0;padding:0 .9em 3px;cursor:pointer;background:0;color:#9c9c9c;font-size:11px;font-weight:bold;height:29px;line-height:29px;-moz-box-sizing:content-box;-ms-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;-moz-border-radius:0;-webkit-border-radius:0;border-radius:0}.ytcenter-settings-subcat-header{border-bottom:1px solid #e6e6e6;height:32px}.ltr .ytcenter-settings-subcat-header li:last-child{margin-right:13px}.rtl .ytcenter-settings-subcat-header li:last-child{margin-left:13px}.ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item.ytcenter-selected,.ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item:hover{height:29px;line-height:29px;vertical-align:bottom;color:#333;border-bottom:3px solid;border-color:#b00;padding-bottom:0;display:inline-block;text-decoration:none}.ytcenter-settings-subcat-content-wrapper{position:relative;padding:8px 8px 31px}.ytcenter-settings-subcat-statusbar-wrapper{position:absolute;bottom:0;padding:9px;color:#999;opacity:0;filter:alpha(opacity=0);-moz-transition:opacity 1s;-webkit-transition:opacity 1s;transition:opacity 1s}.ltr .ytcenter-settings-subcat-statusbar-wrapper{right:0;text-align:right}.rtl .ytcenter-settings-subcat-statusbar-wrapper{left:0;text-align:left}.ytcenter-settings-subcat-statusbar-wrapper.visible{opacity:1;filter:alpha(opacity=100);-moz-transition:opacity .3s;-webkit-transition:opacity .3s;transition:opacity .3s}.ytcenter-settings-option-label{display:inline-block;width:260px;color:#555;vertical-align:middle}.ytcenter-settings-option-label.ytcenter-disabled{color:#b9b9b9}.ytcenter-settings-help{vertical-align:super;font-size:10px}.ytcenter-settings-version{position:absolute;bottom:0;right:0;left:0;color:#bbb;font-size:11px;padding:9px}.ytcenter-settings-subcat-option{margin:4px 8px 4px 0}.ytcenter-settings-table{width:100%}.ytcenter-settings-table tr{border-top:1px solid #ccc;background-color:#fff}.ytcenter-settings-table tr:nth-child(2n){background-color:#f8f8f8}.ytcenter-settings-table thead tr{background-color:#f8f8f8}.ytcenter-settings-table thead tr td{font-weight:bold}.ytcenter-settings-table tr td{border:1px solid #ddd;padding:6px 13px}.ytcenter-theme-dark .ytcenter-dialog-fg{background:#000;border:1px solid #1d1d1d}.ytcenter-theme-dark .ytcenter-dialog-bg{background:#000}.ytcenter-theme-dark .yt-alert .close:hover{background-color:rgba(255,255,255,.15)}.ytcenter-theme-dark .ytcenter-settings-content,.ytcenter-theme-dark .ytcenter-dialog-base .ytcenter-dialog-header h2,.ytcenter-theme-dark .ytcenter-settings-category-list .ytcenter-settings-category-item{color:#aaa}.ytcenter-theme-dark .ytcenter-settings-content a{color:#1a6299}.ytcenter-theme-dark .ytcenter-dialog-base .ytcenter-dialog-header,.ytcenter-theme-dark .ytcenter-settings-subcat-header{border-bottom:1px solid #1d1d1d}.ytcenter-theme-dark .ytcenter-dialog .yt-horizontal-rule{border-top:1px solid #1d1d1d}.ytcenter-theme-dark .ytcenter-settings-option-label{color:#aaa}.ltr.ytcenter-theme-dark .ytcenter-settings-panel-left{border-right:1px solid #1d1d1d}.rtl.ytcenter-theme-dark .ytcenter-settings-panel-left{border-left:1px solid #1d1d1d}.ytcenter-theme-dark .ytcenter-settings-category-list .ytcenter-settings-category-item:hover{background:#333}.ytcenter-theme-dark .ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item{color:#636363}.ytcenter-theme-dark .ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item.ytcenter-selected,.ytcenter-theme-dark .ytcenter-settings-subcat-header .ytcenter-settings-subcat-header-item:hover{color:#ccc;border-color:#400}.ytcenter-theme-dark .ytcenter-settings-table tr{border-top:1px solid #333;background-color:#000}.ytcenter-theme-dark .ytcenter-settings-table tr:nth-child(2n){background-color:#070707}.ytcenter-theme-dark .ytcenter-settings-table thead tr{background-color:#070707}.ytcenter-theme-dark .ytcenter-settings-table thead tr td{font-weight:bold}.ytcenter-theme-dark .ytcenter-settings-table tr td{border:1px solid #222;padding:6px 13px}.ytcenter-theme-dark .ytcenter-settings-category-list .ytcenter-settings-category-item:hover{color:#ddd}.ytcenter-theme-dark .ytcenter-settings-category-list .ytcenter-settings-category-item.ytcenter-selected{background:#330607;color:#fff}.ytcenter-dialog{font-family:arial,sans-serif;font-size:13px;line-height:1;text-align:left;text-align:start}", | |
centering: ".ytcenter-site-center #yt-masthead,.ytcenter-site-center #footer-hh{width:1003px!important}#page.search.no-flex .branded-page-v2-container{min-width:0!important}.ytcenter-exp-settings-dialog .ytcenter-settings-content,.ytcenter-exp-settings-dialog .ytcenter-settings-content>div{padding-left:0!important}.ytcenter-exp-settings-dialog .yt-uix-form-textarea{width:100%!important}.ytcenter-site-center #alerts{margin:0 auto!important}.ytcenter-site-center #sb-wrapper{width:1003px!important}body.ytcenter-channelv2 #yt-masthead,body.ytcenter-channelv2 #page-container>#page.channel{width:auto!important;min-width:1003px;max-width:1422px}body.ytcenter-channelv2 #page.channel>#guide+#content{width:auto!important}.ytcenter-site-center #page-container>#page{margin:0 auto!important}.ytcenter-site-center #masthead-subnav>ul{width:1003px;margin:0 auto!important}.ytcenter-site-center #page.channel.page-default{width:100%!important}.ytcenter-site-center #content-container #baseDiv,.ytcenter-site-center #masthead-subnav{margin-left:auto!important;margin-right:auto!important}.ytcenter-site-center #footer-container #footer{width:1003px!important;margin-left:auto!important;margin-right:auto!important}.ytcenter-site-center #yt-masthead-container #yt-masthead,.ytcenter-site-center #header,.ytcenter-site-center #alerts{width:1003px;margin:0 auto!important;padding:0 10px!important}.ytcenter-site-search.ytcenter-site-center.exp-new-site-width #guide+#content{width:823px!important}.ytcenter-site-search.ytcenter-site-center.exp-new-site-width #page{width:1003px!important}.ytcenter-site-not-watch.ytcenter-site-center #page{width:1003px}.ytcenter-site-not-watch.ytcenter-site-center #page-container{padding:0 10px!important}.ytcenter-site-not-watch.ytcenter-site-center.flex-width-enabled #page{padding:0 10px!important}.flex-width-enabled #yt-masthead{width:auto!important;max-width:1422px!important;min-width:1003px!important}.flex-width-enabled.exp-top-guide #yt-masthead,.flex-width-enabled.site-center-aligned #yt-masthead,.flex-width-enabled.site-as-giant-card #yt-masthead{width:auto!important;max-width:none!important;min-width:none!important}.ytcenter-site-center.ytcenter-non-resize #player,.ytcenter-site-center.ytcenter-non-resize #player-legacy,.ytcenter-site-center.ytcenter-non-resize #content,.ytcenter-site-center.ytcenter-non-resize #watch7-main-container{width:1003px!important;padding-left:0!important;padding-right:0!important}@media screen and (max-width:1381px){.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #content{margin:0!important}.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #player,.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #player-legacy,.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #watch7-main-container{padding-left:190px!important;padding-right:190px!important;margin:0!important}.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #guide-container{left:10px!important}.rtl.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible #guide-container{right:10px!important}}@media screen and (max-width:1165px){.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player,.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player-legacy,.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #watch7-main-container{margin:0!important}.ltr.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player,.ltr.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player-legacy,.ltr.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #watch7-main-container{padding-left:58px!important}.rtl.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player,.rtl.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #player-legacy,.rtl.ytcenter-site-center.ytcenter-non-resize.ytcenter-guide-visible.guide-collapsed #watch7-main-container{padding-right:58px!important}.ltr.ytcenter-site-notcenter.ytcenter-resize-disaligned #player,.ltr.ytcenter-site-notcenter.ytcenter-resize-disaligned #player-legacy{padding-left:0!important}.rtl.ytcenter-site-notcenter.ytcenter-resize-disaligned #player,.rtl.ytcenter-site-notcenter.ytcenter-resize-disaligned #player-legacy{padding-right:0!important}}.ltr.ytcenter-site-notcenter.ytcenter-resize-disaligned #player,.ltr.ytcenter-site-notcenter.ytcenter-resize-disaligned #player-legacy{padding-left:0}.rtl.ytcenter-site-notcenter.ytcenter-resize-disaligned #player,.rtl.ytcenter-site-notcenter.ytcenter-resize-disaligned #player-legacy{padding-left:0}", | |
embed: "#cued-embed .video-thumbnail{padding-top:30px;height:100%;background-size:100%;background-repeat:no-repeat;background-position:center}", | |
player: "body.ytcenter-player-gap .watch-stage-mode #player,body.ytcenter-player-gap .watch-stage-mode #placeholder-player{margin-top:0}.watch-stage-mode #player-playlist .radio-playlist .playlist-videos-list{max-height:360px!important}#placeholder-player .player-api{max-width:0}.ytcenter-resize .watch-stage-mode #player-api,.ytcenter-resize .watch-stage-mode #player-unavailable{left:initial!important;right:initial!important;margin:0 auto!important;position:relative}#player-unavailable:not(.hid)+#player-api{display:none}.ytcenter-resize .exp-watch-controls-overlay #watch-sidebar-spacer{height:0!important}.ytcenter-resize #player-api{position:relative}.ytcenter-resize #player{width:100%!important}.ytcenter-resize #player-mole-container{position:absolute;width:100%}body.ytcenter-scrolled-top{overflow:hidden}.ytcenter-scrolled-top #player-playlist,.ytcenter-scrolled-top-player-pre #player-playlist{display:none}.ytcenter-scrolled-top .watch-sidebar{top:0!important}.ytcenter-scrolled-top #page,.ytcenter-scrolled-top-player-pre #page{position:static!important}.ytcenter-scrolled-top #player-mole-container,.ytcenter-scrolled-top-player-pre #player-mole-container,.ytcenter-scrolled-top #player,.ytcenter-scrolled-top-player-pre #player{position:static!important}.ytcenter-scrolled-top #player,.ytcenter-scrolled-top #player-legacy{overflow:visible!important}.ytcenter-scrolled-top-player-pre #player-api,.ytcenter-scrolled-top-player-pre #player-api-legacy{width:100%!important;height:100%!important;position:absolute!important;top:-100%!important}.ltr.ytcenter-scrolled-top-player-pre #player-api,.ltr.ytcenter-scrolled-top-player-pre #player-api-legacy,.ltr.ytcenter-scrolled-top #player-api,.ltr.ytcenter-scrolled-top #player-api-legacy{left:0!important;margin-left:0!important;margin-right:0!important}.rtl.ytcenter-scrolled-top-player-pre #player-api,.rtl.ytcenter-scrolled-top-player-pre #player-api-legacy,.rtl.ytcenter-scrolled-top #player-api,.rtl.ytcenter-scrolled-top #player-api-legacy{right:0!important;margin-left:0!important;margin-right:0!important}.ytcenter-scrolled-top #player-api,.ytcenter-scrolled-top #player-api-legacy{width:100%!important;height:100%!important;position:absolute!important;top:0!important;-moz-transition:top .5s linear;-ms-transition:top .5s linear;-o-transition:top .5s linear;-webkit-transition:top .5s linear;transition:top .5s linear}.ltr.ytcenter-scrolled-top #page{padding-left:0!important}.rtl.ytcenter-scrolled-top #page{padding-right:0!important}.ytcenter-scrolled-top-element{display:none}.ytcenter-site-watch .ytcenter-scrolled-top-element{width:100%;height:0;background:#000;-moz-transition:height .5s linear;-ms-transition:height .5s linear;-o-transition:height .5s linear;-webkit-transition:height .5s linear;transition:height .5s linear;display:block}.ytcenter-scrolled-top .ytcenter-scrolled-top-element{height:100%}.ytcenter-scrolled-inverse #player-api,.ytcenter-scrolled-inverse #player-api-legacy{margin-top:0!important}.ytcenter-scrolled-top.ytcenter-scrolled-inverse .ytcenter-scrolled-top-element{padding-bottom:0}.ytcenter-scrolled-top-noscrollbar{overflow:hidden!important}.ytcenter-scrolled-top #masthead-positioner,.ytcenter-scrolled-top-static #masthead-positioner{position:static!important}.ytcenter-scrolled-top #masthead-positioner-height-offset,.ytcenter-scrolled-top-static #masthead-positioner-height-offset{display:none!important}.ytcenter-scrolled-top #guide,.ytcenter-scrolled-top-static #guide{display:none!important}.ytcenter-scrolled-top-disable-animation .ytcenter-scrolled-top-element,.ytcenter-scrolled-top-disable-animation.ytcenter-scrolled-top #player-api,.ytcenter-scrolled-top-disable-animation.ytcenter-scrolled-top #player-api-legacy,.ytcenter-scrolled-top-player-pre #player-api,.ytcenter-scrolled-top-player-pre #player-api-legacy{-moz-transition:none!important;-ms-transition:none!important;-o-transition:none!important;-webkit-transition:none!important;transition:none!important}", | |
darkside: "body #player #theater-background,body.ytcenter-player-darkside-bg #player.watch-small #theater-background{display:none}body.ytcenter-player-darkside-bg #player #theater-background{display:block;position:absolute;left:0;margin-top:0;width:100%;-moz-transition:background-color .3s ease;-webkit-transition:background-color .3s ease;transition:background-color .3s ease;background-color:#1b1b1b}body.ytcenter-player-darkside-bg.ytcenter-player-darkside-bg-retro #player #theater-background{background-color:#444;background-image:-moz-linear-gradient(top,#555,#333);background-image:-webkit-gradient(linear,left top,left bottom,from(#555),to(#333));filter:progid:DXImageTransform.Microsoft.Gradient(gradientType=0,startColorStr='#555555',endColorStr='#333333')}body.ytcenter-player-darkside-bg #player{background-color:#1b1b1b}", | |
feather: ".yt-uix-form-input-select,.yt-uix-form-input-text,.yt-uix-form-input-textarea{border:1px solid #d3d3d3;color:#333}.yt-uix-form-input-select{position:relative;display:inline-block;font-weight:bold;font-size:11px;vertical-align:middle;cursor:pointer;overflow:hidden;text-shadow:0 1px 0 rgba(255,255,255,.5);background-color:#f8f8f8;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#fffcfcfc,EndColorStr=#fff8f8f8);background-image:-moz-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-ms-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-o-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:-webkit-linear-gradient(top,#fcfcfc 0,#f8f8f8 100%);background-image:linear-gradient(to bottom,#fcfcfc 0,#f8f8f8 100%)}.yt-uix-form-input-select-content{position:absolute;top:0;left:0;width:100%;height:100%;line-height:26px}.yt-uix-form-input-select-arrow{float:right;width:0;height:0;border:1px solid transparent;border-width:4px 4px 0;border-top-color:#666;margin-top:11px;margin-right:10px}.yt-uix-form-input-select-value{display:block;margin:0 10px;overflow:hidden;white-space:nowrap;word-wrap:normal;-o-text-overflow:ellipsis;text-overflow:ellipsis}.yt-uix-form-input-select-element{position:relative;height:26px;padding:0 1.65em;-webkit-appearance:none;-moz-appearance:none;opacity:0;filter:alpha(opacity=0);_filter:none}.yt-uix-form-input-select-element option{padding:0}.yt-uix-form-input-radio-container,.yt-uix-form-input-checkbox-container{position:relative;display:inline-block;height:20px;line-height:0;font-size:0;vertical-align:middle}.yt-uix-form-input-checkbox,.yt-uix-form-input-checkbox-element{width:14px;height:14px}.yt-uix-form-input-radio-container input,.yt-uix-form-input-checkbox-container input{cursor:pointer;position:absolute;top:1px;left:1px;border:0;outline:0;margin:0;padding:0;opacity:0;filter:alpha(opacity=0);-moz-appearance:none;-webkit-appearance:none}.yt-uix-form-input-checkbox-element,.yt-uix-form-input-radio-element,.yt-uix-form-input-text,.yt-uix-form-input-textarea{box-shadow:inset 0 0 1px rgba(0,0,0,.05)}.yt-uix-form-input-radio-element,.yt-uix-form-input-checkbox-element{border:1px solid #c6c6c6;display:inline-block;vertical-align:middle;cursor:pointer}.yt-uix-form-input-checkbox-container:hover .yt-uix-form-input-checkbox-element,.yt-uix-form-input-radio-container:hover .yt-uix-form-input-radio-element{border-color:#b9b9b9}.yt-uix-form-input-checkbox-container input:checked+.yt-uix-form-input-checkbox-element{background:no-repeat url();border:1px solid #36649c}.ytcenter-dialog menu,.ytcenter-dialog ol,.ytcenter-dialog ul{list-style:none}.yt-uix-form-input-text{width:250px;padding:5px 10px 6px;margin-top:0;margin-bottom:0;font-size:13px}.yt-uix-form-input-select:hover,.yt-uix-form-input-text:hover,.yt-uix-form-input-textarea:hover{border-color:#b9b9b9}.yt-uix-form-input-select.focused,.yt-uix-form-input-checkbox:focus+.yt-uix-form-input-checkbox-element,.yt-uix-form-input-radio:focus+.yt-uix-form-input-radio-element,.yt-uix-form-input-text:focus,.yt-uix-form-input-textarea:focus{outline:0;border-color:#1b7fcc;box-shadow:inset 0 0 1px rgba(0,0,0,.1)}.yt-horizontal-rule{position:relative;margin:20px;height:0;border-top:1px solid #e2e2e2;border-bottom:0}.yt-uix-button{display:inline-block;height:28px;border:solid 1px transparent;padding:0 10px;outline:0;font-weight:bold;font-size:11px;text-decoration:none;white-space:nowrap;word-wrap:normal;line-height:normal;vertical-align:middle;cursor:pointer;border-radius:2px;box-shadow:0 1px 0 rgba(0,0,0,0.05)}.yt-uix-button-default,.yt-uix-button-default[disabled],.yt-uix-button-default[disabled]:hover,.yt-uix-button-default[disabled]:active,.yt-uix-button-default[disabled]:focus{border-color:#d3d3d3;background:#f8f8f8;color:#333}.yt-uix-tooltip{display:inline-block}.yt-uix-button-arrow{margin-top:-3px;margin-left:5px;border:1px solid transparent;border-top-color:#333;border-width:4px 4px 0;width:0;height:0}.yt-uix-button img,.yt-uix-button-icon-wrapper+.yt-uix-button-content{vertical-align:middle}.yt-uix-button:focus,.yt-uix-button:focus:hover,.yt-uix-button-focused,.yt-uix-button-focused:hover{box-shadow:0 0 0 2px rgba(27,127,204,0.4)}.yt-uix-button-default:hover,.yt-uix-button-text:hover{border-color:#c6c6c6;background:#f0f0f0;box-shadow:0 1px 0 rgba(0,0,0,0.10)}.yt-uix-button-menu{outline:0;padding:8px 0;position:absolute;border:1px solid #ccc;z-index:2147483647;overflow:auto;background:#fff;border-radius:2px}.yt-uix-button-menu-external{overflow:visible}.yt-uix-button .yt-uix-button-menu{display:none}.yt-uix-button-default:active,.yt-uix-button-default.yt-uix-button-toggled,.yt-uix-button-default.yt-uix-button-active,.yt-uix-button-default.yt-uix-button-active:focus,.yt-uix-button-text:active{border-color:#c6c6c6;background:#e9e9e9;box-shadow:inset 0 1px 0 #ddd}.yt-uix-button-menu li{margin:0;padding:0}.yt-uix-button-menu .yt-uix-button-menu-item{display:block;margin:0;padding:0 25px;color:#333;font-size:13px;text-decoration:none;white-space:nowrap;word-wrap:normal;line-height:25px;cursor:pointer;cursor:hand}.yt-uix-button-primary,.yt-uix-button-primary[disabled],.yt-uix-button-primary[disabled]:hover,.yt-uix-button-primary[disabled]:active,.yt-uix-button-primary[disabled]:focus{border-color:#1b7fcc;background:#1b7fcc;color:#fff}.yt-uix-button-primary:hover{background:#126db3}.yt-uix-button-group{display:inline-block;white-space:nowrap;vertical-align:middle}.yt-uix-button:hover{text-decoration:none}.yt-uix-button-group .yt-uix-button{margin-right:-2px;border-radius:0}.yt-uix-button-group .start{-moz-border-radius-topleft:2px;border-top-left-radius:2px;-moz-border-radius-bottomleft:2px;border-bottom-left-radius:2px}.yt-uix-button-group .end{margin-right:0;-moz-border-radius-topright:2px;border-top-right-radius:2px;-moz-border-radius-bottomright:2px;border-bottom-right-radius:2px}.yt-uix-button-default:hover,.yt-uix-button-text:hover{border-color:#c6c6c6;background:#f0f0f0;box-shadow:0 1px 0 rgba(0,0,0,0.10)}.yt-uix-button-group .yt-uix-button:hover{position:relative;z-index:2147483645}.yt-uix-button-text,.yt-uix-button-text[disabled]{border:solid 1px transparent;outline:0;background:0;color:#333;box-shadow:none}", | |
elementFocus: ".element-focus-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:19999999999;background:#000;opacity:.75}.element-focus-wrapper{position:absolute;z-index:199999999999}.element-focus{position:relative;background:#fff;-moz-box-shadow:inset 0 0 10px #000;-webkit-box-shadow:inset 0 0 10px #000;box-shadow:inset 0 0 10px #000}.element-focus>.element-focus-container{position:relative}.element-focus-btn-wrapper{padding:10px;background:#fff;text-align:right;margin-top:10px;-moz-box-shadow:inset 0 0 10px #000;-webkit-box-shadow:inset 0 0 10px #000;box-shadow:inset 0 0 10px #000}.element-focus-btn-wrapper button{margin-left:10px}" | |
/*, | |
yonez: "@styles-yonez-clean-yt@"*/ | |
}; | |
ytcenter.topScrollPlayer = (function(){ | |
function enterComplete() { | |
if (inTransition) { | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-player-pre"); | |
uw.setTimeout(function(){ inTransition = false; }, 500); | |
window.dispatchEvent(ytcenter.utils.createCustomEvent("resize", "ytcenter")); | |
} | |
} | |
function exitComplete() { | |
if (inTransition) { | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-static"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
inTransition = false; | |
window.dispatchEvent(ytcenter.utils.createCustomEvent("resize", "ytcenter")); | |
} | |
} | |
function onTransitionEnd() { | |
if (!transitionEndListenerAdded) { | |
inTransition = true; | |
if (inTransitionTimer !== null) { | |
uw.clearTimeout(inTransitionTimer); | |
} | |
var fullscreenData = { fullscreen: activated }; | |
var api = ytcenter.player.getAPI(); | |
if (api && api.getVideoData) { | |
var data = api.getVideoData(); | |
fullscreenData.videoId = data.video_id; | |
if (data.list) { | |
fullscreenData.listId = data.list; | |
} | |
ytcenter.player.listeners.fireEvent("onFullscreenChange", fullscreenData); | |
} | |
if (activated) { | |
inTransitionTimer = uw.setTimeout(function(){ enterComplete(); inTransitionTimer = null; }, 50); | |
} else { | |
inTransitionTimer = uw.setTimeout(function(){ exitComplete(); inTransitionTimer = null; }, 500); | |
} | |
} | |
window.dispatchEvent(ytcenter.utils.createCustomEvent("resize", "ytcenter")); | |
} | |
function onTransitionEndListener() { | |
if (activated) { | |
enterComplete(); | |
} else { | |
exitComplete(); | |
} | |
} | |
function scroll(e, delta, deltaX, deltaY) { | |
if (!enabled || inTransition) return; | |
if (ytcenter.settingsPanelDialog && ytcenter.settingsPanelDialog.isVisible()) return; | |
if (ytcenter.html5) { | |
var playlistPlayerTray = document.getElementsByClassName("ytp-playlist-tray-container"); | |
if (playlistPlayerTray && playlistPlayerTray.length > 0 && playlistPlayerTray[0] && ytcenter.utils.isParent(playlistPlayerTray[0], e.target)) { | |
return; | |
} | |
} | |
var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; | |
var pa = document.getElementById("player-api") || document.getElementById("player-api-legacy"), | |
p = document.getElementById("player") || document.getElementById("player-api"), | |
api = ytcenter.player.getAPI(), | |
scrollUpExit = ytcenter.settings.topScrollPlayerScrollUpToExit; | |
if (document.getElementById("player")) { | |
document.getElementById("player").style.position = ""; | |
} | |
if (activated) { | |
if ((deltaY < 0 && !scrollUpExit) || (deltaY > 0 && scrollUpExit)) { | |
if (ytcenter.settings.topScrollPlayerTimesToExit > count) { | |
exports.bumpCount(); | |
count++; | |
//ytcenter.utils.scrollTop(scrollUpExit ? 1 : 0); | |
} else { | |
//ytcenter.utils.scrollTop(1); | |
p.style.height = ""; | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-inverse"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-static"); | |
activated = false; | |
onTransitionEnd(); | |
count = 0; | |
exports.stopTimer(); | |
setTimeout(function(){ ytcenter.utils.scrollTop(0); }, 7); | |
} | |
} else if (scrollUpExit) { | |
setTimeout(function(){ ytcenter.utils.scrollTop(0); }, 7); | |
//ytcenter.utils.scrollTop(1); | |
} | |
} else { | |
if (scrollTop === 0 && deltaY > 0) { | |
if (ytcenter.settings.topScrollPlayerTimesToEnter > count) { | |
exports.bumpCount(); | |
count++; | |
} else { | |
if (ytcenter.settings.topScrollPlayerEnabledOnlyVideoPlaying && (!api || !api.getPlayerState || api.getPlayerState() !== 1)) { | |
return; | |
} | |
p.style.height = pa.style.height; | |
if (!ytcenter.settings.topScrollPlayerAnimation) | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-player-pre"); | |
if (scrollUpExit) ytcenter.utils.addClass(document.body, "ytcenter-scrolled-inverse"); | |
activated = true; | |
onTransitionEnd(); | |
count = 0; | |
exports.stopTimer(); | |
setTimeout(function(){ ytcenter.utils.scrollTop(0); }, 7); | |
} | |
} else if (scrollTop === 0 && ytcenter.settings.topScrollPlayerCountIncreaseBefore) { | |
exports.bumpCount(); | |
count++; | |
} | |
} | |
} | |
function addEventListeners() { | |
if (throttleFunc) ytcenter.scrollEvent.removeEventListener(window, throttleFunc); | |
throttleFunc = ytcenter.utils.throttle(scroll, throttleTimer); | |
ytcenter.scrollEvent.addEventListener(window, throttleFunc); | |
} | |
function removeEventListener() { | |
if (throttleFunc) ytcenter.scrollEvent.removeEventListener(window, throttleFunc); | |
throttleFunc = null; | |
} | |
function setEnabled(a) { | |
var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; | |
enabled = a; | |
if (enabled && ytcenter.getPage() !== "watch") enabled = false; | |
removeEventListener(); | |
if (!enabled) { | |
if (elm && elm.parentNode) elm.parentNode.removeChild(elm); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-inverse"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-player-pre"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
} else { | |
addEventListeners(); | |
if (elm) { | |
if (!elm.parentNode) { | |
document.body.insertBefore(elm, document.body.children[0]); | |
} | |
} else { | |
elm = document.createElement("div"); | |
elm.className = "ytcenter-scrolled-top-element"; | |
document.body.insertBefore(elm, document.body.children[0]); | |
} | |
} | |
} | |
function enter() { | |
p.style.height = pa.style.height; | |
if (!ytcenter.settings.topScrollPlayerAnimation) | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-player-pre"); | |
if (scrollUpExit) ytcenter.utils.addClass(document.body, "ytcenter-scrolled-inverse"); | |
activated = true; | |
onTransitionEnd(); | |
count = 0; | |
exports.stopTimer(); | |
} | |
function exit() { | |
p.style.height = ""; | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-inverse"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-static"); | |
activated = false; | |
onTransitionEnd(); | |
count = 0; | |
exports.stopTimer(); | |
} | |
function setRedirectURL(url) { | |
redirectURL = url; | |
} | |
function isActive() { | |
return activated; | |
} | |
var exports = {}; | |
var count = 0; | |
var activated = false; | |
var enabled = null; | |
var elm = null; | |
var timer = null; | |
var buffer = null; | |
var throttleTimer = 50; | |
var throttleFunc = null; | |
var prev = null; | |
var transitionEndListenerAdded = false; | |
var inTransition = false; | |
var inTransitionTimer = null; | |
var redirectURL = null; | |
exports.isActive = isActive; | |
exports.setRedirectURL = setRedirectURL; | |
exports.setEnabled = setEnabled; | |
exports.bumpCount = function(){ | |
uw.clearTimeout(timer); | |
timer = uw.setTimeout(function(){ | |
count = 0; | |
}, ytcenter.settings.topScrollPlayerBumpTimer); | |
}; | |
exports.stopTimer = function(){ | |
uw.clearTimeout(timer); | |
}; | |
exports.setup = function(){ | |
if (elm && elm.parentNode) elm.parentNode.removeChild(elm); | |
if (!elm) { | |
elm = document.createElement("div"); | |
elm.className = "ytcenter-scrolled-top-element"; | |
if (ytcenter.settings.topScrollPlayerEnabled) document.body.insertBefore(elm, document.body.children[0]); | |
} | |
enabled = ytcenter.settings.topScrollPlayerEnabled; | |
activated = ytcenter.settings.topScrollPlayerActivated; | |
removeEventListener(); | |
if (enabled) { | |
if (ytcenter.settings.topScrollPlayerEnabled && ytcenter.getPage() === "watch") { | |
if (activated) { | |
if (!ytcenter.settings.topScrollPlayerAnimation) | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
if (ytcenter.settings.topScrollPlayerScrollUpToExit) ytcenter.utils.addClass(document.body, "ytcenter-scrolled-inverse"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top"); | |
if (ytcenter.settings.topScrollPlayerHideScrollbar) { | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
} else { | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
} | |
//ytcenter.utils.scrollTop(ytcenter.settings.topScrollPlayerScrollUpToExit ? 1 : 0); | |
} else { | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-disable-animation"); | |
//ytcenter.utils.scrollTop(1); | |
} | |
addEventListeners(); | |
} | |
if (document.getElementById("player")) { | |
document.getElementById("player").style.position = ""; | |
} | |
} | |
exports.setEnabled(ytcenter.settings.topScrollPlayerEnabled); | |
ytcenter.player.listeners.addEventListener("onStateChange", function(state){ | |
if (!enabled) return; | |
var p = document.getElementById("player") || document.getElementById("player-api"), | |
pa = document.getElementById("player-api") || document.getElementById("player-api-legacy"), | |
api = ytcenter.player.getAPI(), | |
scrollUpExit = ytcenter.settings.topScrollPlayerScrollUpToExit; | |
if (state === 0 && ytcenter.settings.topScrollPlayerExitOnVideoEnd && activated) { | |
p.style.height = ""; | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-inverse"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top"); | |
ytcenter.utils.removeClass(document.body, "ytcenter-scrolled-top-noscrollbar"); | |
ytcenter.utils.addClass(document.body, "ytcenter-scrolled-top-static"); | |
activated = false; | |
onTransitionEnd(); | |
count = 0; | |
exports.stopTimer(); | |
} else if (state === 1 && ytcenter.settings.topScrollPlayerEnterOnVideoPlay && !activated) { | |
enter(); | |
} else if (state === 2 && ytcenter.settings.topScrollPlayerExitOnVideoPause && activated) { | |
exit(); | |
} | |
}); | |
ytcenter.events.addEvent("settings-update", function(){ | |
exports.setEnabled(ytcenter.settings.topScrollPlayerEnabled); | |
if (enabled) { | |
if (document.getElementById("player")) { | |
document.getElementById("player").style.position = ""; | |
} | |
} | |
}); | |
ytcenter.events.addEvent("resize-update", function(){ | |
exports.setEnabled(ytcenter.settings.topScrollPlayerEnabled); | |
if (enabled) { | |
if (document.getElementById("player")) { | |
document.getElementById("player").style.position = ""; | |
} | |
} | |
}); | |
}; | |
return exports; | |
})(); | |
ytcenter.flags = { | |
"unknown": "ytcenter-flag-unknown", | |
/* Country Code : CSS Class */ | |
"ad": "ytcenter-flag-ad", | |
"ae": "ytcenter-flag-ae", | |
"af": "ytcenter-flag-af", | |
"ag": "ytcenter-flag-ag", | |
"ai": "ytcenter-flag-ai", | |
"al": "ytcenter-flag-al", | |
"am": "ytcenter-flag-am", | |
"an": "ytcenter-flag-an", | |
"ao": "ytcenter-flag-ao", | |
"aq": "ytcenter-flag-aq", | |
"ar": "ytcenter-flag-ar", | |
"as": "ytcenter-flag-as", | |
"at": "ytcenter-flag-at", | |
"au": "ytcenter-flag-au", | |
"aw": "ytcenter-flag-aw", | |
"ax": "ytcenter-flag-ax", | |
"az": "ytcenter-flag-az", | |
"ba": "ytcenter-flag-ba", | |
"bb": "ytcenter-flag-bb", | |
"bd": "ytcenter-flag-bd", | |
"be": "ytcenter-flag-be", | |
"bf": "ytcenter-flag-bf", | |
"bg": "ytcenter-flag-bg", | |
"bh": "ytcenter-flag-bh", | |
"bi": "ytcenter-flag-bi", | |
"bj": "ytcenter-flag-bj", | |
"bm": "ytcenter-flag-bm", | |
"bn": "ytcenter-flag-bn", | |
"bo": "ytcenter-flag-bo", | |
"br": "ytcenter-flag-br", | |
"bs": "ytcenter-flag-bs", | |
"bt": "ytcenter-flag-bt", | |
"bv": "ytcenter-flag-bv", | |
"bw": "ytcenter-flag-bw", | |
"by": "ytcenter-flag-by", | |
"bz": "ytcenter-flag-bz", | |
"ca": "ytcenter-flag-ca", | |
"catalonia": "ytcenter-flag-catalonia", | |
"cc": "ytcenter-flag-cc", | |
"cd": "ytcenter-flag-cd", | |
"cf": "ytcenter-flag-cf", | |
"cg": "ytcenter-flag-cg", | |
"ch": "ytcenter-flag-ch", | |
"ci": "ytcenter-flag-ci", | |
"ck": "ytcenter-flag-ck", | |
"cl": "ytcenter-flag-cl", | |
"cm": "ytcenter-flag-cm", | |
"cn": "ytcenter-flag-cn", | |
"co": "ytcenter-flag-co", | |
"cr": "ytcenter-flag-cr", | |
"cs": "ytcenter-flag-cs", | |
"cu": "ytcenter-flag-cu", | |
"cv": "ytcenter-flag-cv", | |
"cx": "ytcenter-flag-cx", | |
"cy": "ytcenter-flag-cy", | |
"cz": "ytcenter-flag-cz", | |
"de": "ytcenter-flag-de", | |
"dj": "ytcenter-flag-dj", | |
"dk": "ytcenter-flag-dk", | |
"dm": "ytcenter-flag-dm", | |
"do": "ytcenter-flag-do", | |
"dz": "ytcenter-flag-dz", | |
"ec": "ytcenter-flag-ec", | |
"ee": "ytcenter-flag-ee", | |
"eg": "ytcenter-flag-eg", | |
"eh": "ytcenter-flag-eh", | |
"england": "ytcenter-flag-england", | |
"er": "ytcenter-flag-er", | |
"es": "ytcenter-flag-es", | |
"et": "ytcenter-flag-et", | |
"europeanunion": "ytcenter-flag-europeanunion", | |
"fam": "ytcenter-flag-fam", | |
"fi": "ytcenter-flag-fi", | |
"fj": "ytcenter-flag-fj", | |
"fk": "ytcenter-flag-fk", | |
"fm": "ytcenter-flag-fm", | |
"fo": "ytcenter-flag-fo", | |
"fr": "ytcenter-flag-fr", | |
"ga": "ytcenter-flag-ga", | |
"gb": "ytcenter-flag-gb", | |
"gd": "ytcenter-flag-gd", | |
"ge": "ytcenter-flag-ge", | |
"gf": "ytcenter-flag-gf", | |
"gh": "ytcenter-flag-gh", | |
"gi": "ytcenter-flag-gi", | |
"gl": "ytcenter-flag-gl", | |
"gm": "ytcenter-flag-gm", | |
"gn": "ytcenter-flag-gn", | |
"gp": "ytcenter-flag-gp", | |
"gq": "ytcenter-flag-gq", | |
"gr": "ytcenter-flag-gr", | |
"gs": "ytcenter-flag-gs", | |
"gt": "ytcenter-flag-gt", | |
"gu": "ytcenter-flag-gu", | |
"gw": "ytcenter-flag-gw", | |
"gy": "ytcenter-flag-gy", | |
"hk": "ytcenter-flag-hk", | |
"hm": "ytcenter-flag-hm", | |
"hn": "ytcenter-flag-hn", | |
"hr": "ytcenter-flag-hr", | |
"ht": "ytcenter-flag-ht", | |
"hu": "ytcenter-flag-hu", | |
"id": "ytcenter-flag-id", | |
"ie": "ytcenter-flag-ie", | |
"il": "ytcenter-flag-il", | |
"in": "ytcenter-flag-in", | |
"io": "ytcenter-flag-io", | |
"iq": "ytcenter-flag-iq", | |
"ir": "ytcenter-flag-ir", | |
"is": "ytcenter-flag-is", | |
"it": "ytcenter-flag-it", | |
"jm": "ytcenter-flag-jm", | |
"jo": "ytcenter-flag-jo", | |
"jp": "ytcenter-flag-jp", | |
"ke": "ytcenter-flag-ke", | |
"kg": "ytcenter-flag-kg", | |
"kh": "ytcenter-flag-kh", | |
"ki": "ytcenter-flag-ki", | |
"km": "ytcenter-flag-km", | |
"kn": "ytcenter-flag-kn", | |
"kp": "ytcenter-flag-kp", | |
"kr": "ytcenter-flag-kr", | |
"kw": "ytcenter-flag-kw", | |
"ky": "ytcenter-flag-ky", | |
"kz": "ytcenter-flag-kz", | |
"la": "ytcenter-flag-la", | |
"lb": "ytcenter-flag-lb", | |
"lc": "ytcenter-flag-lc", | |
"li": "ytcenter-flag-li", | |
"lk": "ytcenter-flag-lk", | |
"lr": "ytcenter-flag-lr", | |
"ls": "ytcenter-flag-ls", | |
"lt": "ytcenter-flag-lt", | |
"lu": "ytcenter-flag-lu", | |
"lv": "ytcenter-flag-lv", | |
"ly": "ytcenter-flag-ly", | |
"ma": "ytcenter-flag-ma", | |
"mc": "ytcenter-flag-mc", | |
"md": "ytcenter-flag-md", | |
"me": "ytcenter-flag-me", | |
"mg": "ytcenter-flag-mg", | |
"mh": "ytcenter-flag-mh", | |
"mk": "ytcenter-flag-mk", | |
"ml": "ytcenter-flag-ml", | |
"mm": "ytcenter-flag-mm", | |
"mn": "ytcenter-flag-mn", | |
"mo": "ytcenter-flag-mo", | |
"mp": "ytcenter-flag-mp", | |
"mq": "ytcenter-flag-mq", | |
"mr": "ytcenter-flag-mr", | |
"ms": "ytcenter-flag-ms", | |
"mt": "ytcenter-flag-mt", | |
"mu": "ytcenter-flag-mu", | |
"mv": "ytcenter-flag-mv", | |
"mw": "ytcenter-flag-mw", | |
"mx": "ytcenter-flag-mx", | |
"my": "ytcenter-flag-my", | |
"mz": "ytcenter-flag-mz", | |
"na": "ytcenter-flag-na", | |
"nc": "ytcenter-flag-nc", | |
"ne": "ytcenter-flag-ne", | |
"nf": "ytcenter-flag-nf", | |
"ng": "ytcenter-flag-ng", | |
"ni": "ytcenter-flag-ni", | |
"nl": "ytcenter-flag-nl", | |
"no": "ytcenter-flag-no", | |
"np": "ytcenter-flag-np", | |
"nr": "ytcenter-flag-nr", | |
"nu": "ytcenter-flag-nu", | |
"nz": "ytcenter-flag-nz", | |
"om": "ytcenter-flag-om", | |
"pa": "ytcenter-flag-pa", | |
"pe": "ytcenter-flag-pe", | |
"pf": "ytcenter-flag-pf", | |
"pg": "ytcenter-flag-pg", | |
"ph": "ytcenter-flag-ph", | |
"pk": "ytcenter-flag-pk", | |
"pl": "ytcenter-flag-pl", | |
"pm": "ytcenter-flag-pm", | |
"pn": "ytcenter-flag-pn", | |
"pr": "ytcenter-flag-pr", | |
"ps": "ytcenter-flag-ps", | |
"pt": "ytcenter-flag-pt", | |
"pw": "ytcenter-flag-pw", | |
"py": "ytcenter-flag-py", | |
"qa": "ytcenter-flag-qa", | |
"re": "ytcenter-flag-re", | |
"ro": "ytcenter-flag-ro", | |
"rs": "ytcenter-flag-rs", | |
"ru": "ytcenter-flag-ru", | |
"rw": "ytcenter-flag-rw", | |
"sa": "ytcenter-flag-sa", | |
"sb": "ytcenter-flag-sb", | |
"sc": "ytcenter-flag-sc", | |
"scotland": "ytcenter-flag-scotland", | |
"sd": "ytcenter-flag-sd", | |
"se": "ytcenter-flag-se", | |
"sg": "ytcenter-flag-sg", | |
"sh": "ytcenter-flag-sh", | |
"si": "ytcenter-flag-si", | |
"sj": "ytcenter-flag-sj", | |
"sk": "ytcenter-flag-sk", | |
"sl": "ytcenter-flag-sl", | |
"sm": "ytcenter-flag-sm", | |
"sn": "ytcenter-flag-sn", | |
"so": "ytcenter-flag-so", | |
"sr": "ytcenter-flag-sr", | |
"st": "ytcenter-flag-st", | |
"sv": "ytcenter-flag-sv", | |
"sy": "ytcenter-flag-sy", | |
"sz": "ytcenter-flag-sz", | |
"tc": "ytcenter-flag-tc", | |
"td": "ytcenter-flag-td", | |
"tf": "ytcenter-flag-tf", | |
"tg": "ytcenter-flag-tg", | |
"th": "ytcenter-flag-th", | |
"tj": "ytcenter-flag-tj", | |
"tk": "ytcenter-flag-tk", | |
"tl": "ytcenter-flag-tl", | |
"tm": "ytcenter-flag-tm", | |
"tn": "ytcenter-flag-tn", | |
"to": "ytcenter-flag-to", | |
"tr": "ytcenter-flag-tr", | |
"tt": "ytcenter-flag-tt", | |
"tv": "ytcenter-flag-tv", | |
"tw": "ytcenter-flag-tw", | |
"tz": "ytcenter-flag-tz", | |
"ua": "ytcenter-flag-ua", | |
"ug": "ytcenter-flag-ug", | |
"um": "ytcenter-flag-um", | |
"us": "ytcenter-flag-us", | |
"uy": "ytcenter-flag-uy", | |
"uz": "ytcenter-flag-uz", | |
"va": "ytcenter-flag-va", | |
"vc": "ytcenter-flag-vc", | |
"ve": "ytcenter-flag-ve", | |
"vg": "ytcenter-flag-vg", | |
"vi": "ytcenter-flag-vi", | |
"vn": "ytcenter-flag-vn", | |
"vu": "ytcenter-flag-vu", | |
"wales": "ytcenter-flag-wales", | |
"wf": "ytcenter-flag-wf", | |
"ws": "ytcenter-flag-ws", | |
"ye": "ytcenter-flag-ye", | |
"yt": "ytcenter-flag-yt", | |
"za": "ytcenter-flag-za", | |
"zm": "ytcenter-flag-zm", | |
"zw": "ytcenter-flag-zw" | |
}; | |
ytcenter.videoHistory = (function(){ | |
var exports = {}; | |
exports.watchedVideos = []; | |
exports.loadWatchedVideosFromYouTubePage = function(){ | |
var a = document.getElementsByClassName("watched"), i, b; | |
for (i = 0; i < a.length; i++) { | |
if (a[i].tagName === "A") { | |
b = ytcenter.utils.getVideoIdFromLink(a[i].getAttribute("href")); | |
if (b && !ytcenter.utils.inArray(exports.watchedVideos, b)) exports.watchedVideos.push(b); | |
} | |
} | |
}; | |
exports.isVideoWatched = function(id){ | |
if (ytcenter.utils.inArray(ytcenter.settings.notwatchedVideos, id)) return false; | |
if (ytcenter.utils.inArray(ytcenter.settings.watchedVideos, id) || ytcenter.utils.inArray(exports.watchedVideos, id)) return true; | |
return false; | |
}; | |
exports.removeVideo = function(id){ | |
var i = ytcenter.utils.inArrayIndex(ytcenter.settings.watchedVideos, id); | |
if (i !== -1) { | |
ytcenter.settings.watchedVideos.splice(i, 1); | |
} | |
if (!ytcenter.utils.inArray(ytcenter.settings.notwatchedVideos, id)) { | |
if (ytcenter.settings.notwatchedVideosLimit < ytcenter.settings.notwatchedVideos.length) { | |
ytcenter.settings.notwatchedVideos.splice(0, ytcenter.settings.notwatchedVideos.length - ytcenter.settings.notwatchedVideosLimit); | |
} | |
ytcenter.settings.notwatchedVideos.push(id); | |
} | |
ytcenter.saveSettings(); | |
}; | |
exports.addVideo = function(id){ | |
var i = ytcenter.utils.inArrayIndex(ytcenter.settings.notwatchedVideos, id); | |
if (i !== -1) { | |
ytcenter.settings.notwatchedVideos.splice(i, 1); | |
} | |
if (!ytcenter.utils.inArray(ytcenter.settings.watchedVideos, id)) { | |
if (ytcenter.settings.watchedVideosLimit < ytcenter.settings.watchedVideos.length) { | |
ytcenter.settings.watchedVideos.splice(0, ytcenter.settings.watchedVideos.length - ytcenter.settings.watchedVideosLimit); | |
} | |
ytcenter.settings.watchedVideos.push(id); | |
} | |
ytcenter.saveSettings(); | |
}; | |
return exports; | |
})(); | |
ytcenter.subtitles = (function(){ | |
/** | |
ytcenter.subtitles.getLanguageList(VIDEO_ID, function(doc){ | |
var l = ytcenter.subtitles.parseLanguageList(doc)[0], // Just selecting the first subtitle in the list. | |
filename; | |
if (typeof l.name === "string" && l.name !== "") filename = "[" + l.languageCode + "]" + l.name; // Generating filename | |
else filename = l.languageCode; // Using language code as filename | |
ytcenter.subtitles.getSubtitleLanguage(VIDEO_ID, l.name, l.languageCode, null, function(cc){ // Getting the selected subtitle | |
cc = ytcenter.subtitles.parseSubtitle(cc); // Parsing the selected subtitle to JSON. | |
ytcenter.subtitles.saveSubtitle(cc, "srt", filename); // Downloading the subtitle as srt with generated filename. | |
}); | |
}); | |
**/ | |
var a = {}; | |
a.saveSubtitle = function(cc, type, filename){ | |
if (typeof type !== "string") type = "srt"; | |
var blob; | |
if (type === "srt") { | |
blob = new ytcenter.unsafe.io.Blob([ytcenter.subtitles.convertToSRT(cc)], { "type": "application/octet-stream" }); | |
ytcenter.unsafe.io.saveAs(blob, filename + ".srt"); | |
} else if (type === "cc") { | |
} else { | |
throw new Error("[Subtitles saveSubtitle] Invalid type (" + type + ")!"); | |
} | |
}; | |
a.parseLanguageList = function(doc){ | |
if (!doc.children || doc.children.length <= 0 || doc.children[0].tagName !== "transcript_list") throw new Error("[Subtitles] Invalid language list!"); | |
var tl = doc.children[0].children, | |
i, a = []; | |
for (i = 0; i < tl.length; i++) { | |
a.push({ | |
type: tl[i].tagName, | |
languageCode: tl[i].getAttribute("lang_code") || "", | |
displayedLanguageName: tl[i].getAttribute("lang_translated") || "", | |
name: tl[i].getAttribute("name") || "", | |
kind: tl[i].getAttribute("kind") || "", | |
id: tl[i].getAttribute("id") || "", | |
isDefault: tl[i].getAttribute("lang_default") || false, | |
isTranslateable: tl[i].getAttribute("cantran") || false, | |
formatList: (tl[i].getAttribute("formats") || "").split(",") | |
}); | |
} | |
return a; | |
}; | |
a.parseSubtitle = function(doc){ | |
if (!doc.children || doc.children.length <= 0 || doc.children[0].tagName !== "transcript") throw new Error("[Subtitles] Invalid transcript (" + doc.children[0].tagName + ")!"); | |
var tl = doc.children[0].children, | |
i, a = [], start, dur; | |
for (i = 0; i < tl.length; i++) { | |
if (tl[i].tagName === "text") { | |
start = parseFloat(tl[i].getAttribute("start")); | |
dur = parseFloat(tl[i].getAttribute("dur")); | |
a.push({ | |
start: start, | |
dur: dur, | |
end: start + dur, | |
text: ytcenter.utils.unescapeHTML(tl[i].textContent) | |
}); | |
} else { | |
con.warn("[Subtitles parseSubtitle] Invalid tag name (" + tl[i].tagName + ")!"); | |
} | |
} | |
return a; | |
}; | |
a.convertToSRT = function(cc){ | |
var srt = "", i; | |
for (i = 0; i < cc.length; i++) { | |
srt += (i + 1) + "\r\n" | |
+ ytcenter.utils.srtTimeFormat(cc[i].start) + " --> " + ytcenter.utils.srtTimeFormat(cc[i].end) + "\r\n" | |
+ cc[i].text + "\r\n" | |
+ "\r\n"; | |
} | |
return srt; | |
}; | |
a.getLanguageList = function(videoId, callback, error){ | |
ytcenter.utils.xhr({ | |
url: ytcenter.protocol + "video.google.com/timedtext?type=list&v=" + encodeURIComponent(videoId), | |
method: "GET", | |
onload: function(response){ | |
var doc = ytcenter.utils.parseXML(response.responseText); | |
if (callback) callback(doc); | |
}, | |
onerror: function(){ | |
con.error("[Subtitles] Couldn't load subtitle list for video (" + videoId + ")"); | |
if (error) error(); | |
} | |
}); | |
}; | |
a.getTranslatedLanguageList = function(videoId, callback, error){ | |
ytcenter.utils.xhr({ | |
url: ytcenter.protocol + "video.google.com/timedtext?type=list&tlangs=1&v=" + encodeURIComponent(videoId), | |
method: "GET", | |
onload: function(response){ | |
var doc = ytcenter.utils.parseXML(response.responseText); | |
if (callback) callback(doc); | |
}, | |
onerror: function(){ | |
con.error("[Subtitles] Couldn't load subtitle list for video (" + videoId + ")"); | |
if (error) error(); | |
} | |
}); | |
}; | |
a.getSubtitleLanguage = function(videoId, langName, langCode, translateLang, callback, error){ | |
ytcenter.utils.xhr({ | |
url: ytcenter.protocol + "video.google.com/timedtext?type=track&v=" + encodeURIComponent(videoId) | |
+ (langName ? "&name=" + encodeURIComponent(langName) : "") | |
+ (langCode ? "&lang=" + encodeURIComponent(langCode) : "") | |
+ (translateLang ? "&tlang=" + encodeURIComponent(translateLang) : ""), | |
method: "GET", | |
onload: function(response){ | |
var doc = ytcenter.utils.parseXML(response.responseText); | |
if (callback) callback(doc); | |
}, | |
onerror: function(){ | |
con.error("[Subtitles] Couldn't load subtitle list for video (" + videoId + ")"); | |
if (error) error(); | |
} | |
}); | |
}; | |
return a; | |
})(); | |
ytcenter.commentsLoader = (function(){ | |
function createLoadCommentsButton() { | |
var el = document.createElement("div"); | |
el.className = "yt-card yt-card-has-padding"; | |
var btn = document.createElement("button"); | |
btn.className = "yt-uix-button yt-uix-button-size-default yt-uix-button-expander"; | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.style.borderTop = "none"; | |
btn.style.margin = "-10px 0 -10px"; | |
btn.addEventListener("click", showCommentsFunc, false); | |
var btnText = document.createElement("span"); | |
btnText.className = "yt-uix-button-content"; | |
btnText.textContent = ytcenter.language.getLocale("LOAD_COMMENTS_TEXT"); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
btnText.textContent = ytcenter.language.getLocale("LOAD_COMMENTS_TEXT"); | |
}); | |
btn.appendChild(btnText); | |
el.appendChild(btn); | |
return el; | |
} | |
function fixWidth() { | |
var iframe = discussionElement.getElementsByTagName("iframe"); | |
iframe = iframe.length > 0 ? iframe[0] : null; | |
var container = discussionElement.getElementsByClassName("comments-iframe-container"); | |
container = container.length > 0 ? container[0] : null; | |
if (iframe && container) { | |
iframe.style.width = container.offsetWidth + "px"; | |
} | |
} | |
function showCommentsFunc() { | |
if (discussionElement && loadCommentsElement && loadCommentsElement.parentNode) { | |
discussionElement.style.display = ""; | |
showComments = true; | |
if (discussionElement.parentNode) { | |
loadCommentsElement.parentNode.removeChild(loadCommentsElement); | |
} else { | |
loadCommentsElement.parentNode.replaceChild(discussionElement, loadCommentsElement); | |
} | |
setTimeout(function(){ | |
if (uw.yt && uw.yt.pubsub && uw.yt.pubsub.publish) { | |
uw.yt.pubsub.publish("page-resize", ytcenter.utils.getViewPort()); | |
} | |
fixWidth(); | |
}, 7); | |
} | |
} | |
function update() { | |
var scrolldetect = discussionElement.getAttribute("data-scrolldetect-callback"); | |
if (scrolldetect) { | |
observer.disconnect(); | |
observer = null; | |
if (!showComments) { | |
discussionElement.parentNode.removeChild(discussionElement); | |
} | |
} | |
} | |
function setup() { | |
if (ytcenter.page === "watch" && !ytcenter.settings.enableComments) { | |
showComments = false; | |
loadCommentsElement = createLoadCommentsButton(); | |
discussionElement = document.getElementById("watch-discussion"); | |
if (discussionElement && discussionElement.parentNode) { | |
discussionElement.style.display = "none"; | |
//discussionElement.style.visibility = "hidden"; | |
if (observer) { | |
observer.disconnect(); | |
observer = null; | |
} | |
observer = ytcenter.mutation.observe(discussionElement, { childList: true, subtree: true }, update); | |
discussionElement.parentNode.appendChild(loadCommentsElement); | |
/*discussionElement.parentNode.replaceChild(loadCommentsElement, discussionElement);*/ | |
/*discussionElement.parentNode.removeChild(discussionElement);*/ | |
} | |
} | |
} | |
var loadCommentsElement = null; | |
var discussionElement = null; | |
var observer = null; | |
var observerWidthFix = null; | |
var showComments = false; | |
var exports = {}; | |
exports.setup = setup; | |
return exports; | |
})(); | |
ytcenter.commentsPlus = (function(){ | |
var exports = {}, comments = [], observer = null; | |
ytcenter.unload(function(){ | |
if (observer) { | |
observer.disconnect(); | |
} | |
}); | |
exports.__commentInfoIdNext = 0; | |
exports.getCommentByElement = function(element){ | |
var i; | |
for (i = 0; i < exports.comments.length; i++) { | |
if (exports.comments[i].element === element) return exports.comments[i]; | |
} | |
return null; | |
}; | |
exports.getCommentObject = function(element){ | |
var detail = {}; | |
detail.element = element; | |
detail.entryElement = element.parentNode; | |
detail.contentElement = element.getElementsByClassName("comment-renderer-content")[0]; | |
detail.headerElement = detail.contentElement.getElementsByClassName("comment-renderer-header")[0]; | |
detail.textElement = detail.contentElement.getElementsByClassName("comment-renderer-text")[0]; | |
var repliesRenderer = element.parentNode.parentNode.parentNode; | |
detail.isReply = ytcenter.utils.hasClass(repliesRenderer, "comment-replies-renderer"); | |
detail.hasSource = element.getElementsByClassName("comment-source").length > 0; | |
detail.parentComment = null; | |
if (detail.isReply) { | |
detail.parentComment = exports.getCommentByElement(repliesRenderer.previousElementSibling); | |
} | |
detail.url = element.getElementsByTagName("a")[0].getAttribute("href"); | |
console.log(detail.url); | |
detail.protocol = detail.url.indexOf("https://") === 0 ? "https" : "http"; | |
if (detail.url.indexOf(ytcenter.protocol) !== 0) { | |
if (ytcenter.protocol === "http://") { | |
detail.url = detail.url.replace(/^https/, "http"); | |
} else if (ytcenter.protocol === "https://") { | |
detail.url = detail.url.replace(/^http/, "https"); | |
} | |
} | |
detail.channelId = null; | |
detail.googleId = null; | |
detail.profileId = null; | |
if (detail.url.indexOf("youtube.com/profile_redirector/") !== -1) { | |
detail.profileId = detail.url.split("youtube.com/profile_redirector/")[1]; | |
} else if (detail.url.indexOf("youtube.com/channel/") !== -1) { | |
detail.channelId = detail.url.split("youtube.com/channel/")[1]; | |
} else if (detail.url.indexOf("/channel/") !== -1) { | |
detail.channelId = detail.url.split("/channel/")[1]; | |
} else if (detail.url.indexOf("youtube.com/user/") !== -1) { | |
detail.channelId = detail.url.split("youtube.com/user/")[1]; | |
} else if (detail.url.indexOf("/user/") !== -1) { | |
detail.channelId = detail.url.split("/user/")[1]; | |
} else if (detail.url.indexOf("apis.google.com/u/") !== -1) { | |
var tokens = detail.url.split("/"); | |
detail.googleId = tokens[tokens.length - 1]; | |
} | |
detail.country = ytcenter.cache.getItem("profile_country", detail.profileId || detail.channelId); | |
if (detail.country) { | |
detail.country = detail.country.data; | |
} else { | |
detail.country = null; | |
} | |
detail.flagAdded = false; | |
return detail; | |
}; | |
exports.comments = []; | |
exports.commentLoaded = function(commentObject){ | |
var i; | |
for (i = 0; i < exports.comments.length; i++) { | |
/* Make sure that a comment won't be added multiple times */ | |
if (exports.comments[i].element === commentObject.element) { | |
return true; | |
} | |
} | |
return false; | |
}; | |
exports.addCommentObject = function(commentObject){ | |
//if (ytcenter.utils.hasClass(commentObject.contentElement, "ytcenter-comments-loaded")) return; | |
if (exports.commentLoaded(commentObject)) return; | |
con.log("[CommentsPlus:addCommentObject] Adding new comment with id: " + exports.__commentInfoIdNext + "."); | |
commentObject.id = exports.__commentInfoIdNext; | |
exports.__commentInfoIdNext += 1; | |
exports.comments.push(commentObject); | |
}; | |
exports.loadComments = function(){ | |
var comments = document.getElementsByClassName("comment-renderer"); | |
for (var i = 0; i < comments.length; i++) { | |
try { | |
exports.addCommentObject(exports.getCommentObject(comments[i])); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
}; | |
exports.addFlagPlaceholder = function(comment){ | |
function onLanguageUpdate() { | |
var title = ytcenter.language.getLocale(comment.flagElements.title); | |
img.setAttribute("alt", title); | |
img.setAttribute("title", title); | |
img.setAttribute("data-tooltip-text", title); | |
} | |
comment && comment.unloadLoadButton && comment.unloadLoadButton(); | |
var metadata = comment.headerElement; | |
var container = document.createElement("span"); | |
container.className = "country"; | |
var img = document.createElement("img"); | |
img.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
img.className = "ytcenter-flag-loading"; | |
container.appendChild(img); | |
comment.flagElements = {}; | |
comment.flagElements.container = container; | |
comment.flagElements.img = img; | |
comment.flagElements.title = "COMMENTS_COUNTRY_BUTTON_LOAD_LOADING"; | |
comment.flagElements.onLanguageUpdate = onLanguageUpdate; | |
ytcenter.events.addEvent("language-refresh", onLanguageUpdate); | |
onLanguageUpdate(); | |
exports.addElement(metadata, container, comment); | |
}; | |
exports.completeFlag = function(comment, country){ | |
if (!comment.flagElements) exports.addFlagPlaceholder(comment); | |
var container = comment.flagElements.container; | |
var img = comment.flagElements.img; | |
var onLanguageUpdate = comment.flagElements.onLanguageUpdate; | |
if (ytcenter.settings.commentCountryShowFlag && ytcenter.flags[country.toLowerCase()]) { | |
img.className = ytcenter.flags[country.toLowerCase()]; | |
if (ytcenter.settings.commentCountryUseNames) { | |
if (country === "unknown") { | |
comment.flagElements.title = "COUNTRY_UNKNOWN"; | |
} else { | |
comment.flagElements.title = "COUNTRY_ISO3166-1_CODES_" + country.toUpperCase(); | |
} | |
} else { | |
comment.flagElements.title = country; | |
} | |
onLanguageUpdate(); | |
} else { | |
ytcenter.events.removeEvent("language-refresh", onLanguageUpdate); | |
if (country === "unknown") { | |
var countryName = ytcenter.language.getLocale("COUNTRY_UNKNOWN"); | |
} else { | |
var countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); | |
} | |
if (ytcenter.settings.commentCountryUseNames) { | |
container.textContent = countryName || country; | |
ytcenter.events.addEvent("language-refresh", function(){ | |
if (country === "unknown") { | |
var _countryName = ytcenter.language.getLocale("COUNTRY_UNKNOWN"); | |
} else { | |
var _countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); | |
} | |
container.textContent = _countryName || country; | |
}); | |
} else { | |
container.textContent = country; | |
} | |
} | |
}; | |
exports.addLoadButton = function(comment){ | |
function onLanguageRefresh(){ | |
var title = ytcenter.language.getLocale(btn_text); | |
btn.element.setAttribute("alt", title); | |
btn.element.setAttribute("title", title); | |
btn.element.setAttribute("data-tooltip-text", title); | |
} | |
var countryContainer = document.createElement("span"), | |
metadata = comment.headerElement, btn = null, | |
btn_text = "COMMENTS_COUNTRY_BUTTON_LOAD"; | |
countryContainer.className = "country"; | |
btn = ytcenter.modules.button({ | |
args: { | |
listeners: [ | |
{ | |
event: "click", | |
callback: function(){ | |
if (countryContainer && countryContainer.parentNode) { | |
comment.unloadLoadButton = function(){ | |
countryContainer && countryContainer.parentNode && countryContainer.parentNode.removeChild && countryContainer.parentNode.removeChild(countryContainer); | |
ytcenter.events.removeEvent("language-refresh", onLanguageRefresh); | |
comment.unloadLoadButton = null; | |
btn = null; | |
btn_text = null; | |
countryContainer = null; | |
metadata = null; | |
}; | |
exports.handleFlagWorker(comment); | |
} | |
} | |
} | |
] | |
} | |
}); | |
onLanguageRefresh(); | |
ytcenter.events.addEvent("language-refresh", onLanguageRefresh); | |
btn.element.className += " ytcenter-flag-button yt-uix-tooltip"; | |
btn.element.style.verticalAlign = "middle"; | |
countryContainer.appendChild(btn.element); | |
exports.addElement(metadata, countryContainer, comment); | |
}; | |
exports.addElement = function(metadata, container, comment){ | |
if (ytcenter.settings.commentCountryPosition === "before_username") { | |
container.style.marginRight = "10px"; | |
if (comment.hasSource) { | |
metadata.insertBefore(container, metadata.children[1]); | |
} else { | |
metadata.insertBefore(container, metadata.children[0]); | |
} | |
} else if (ytcenter.settings.commentCountryPosition === "after_username") { | |
container.style.marginLeft = "6px"; | |
if (comment.hasSource) { | |
metadata.insertBefore(container, metadata.childNodes[2]); | |
} else { | |
metadata.insertBefore(container, metadata.children[1]); | |
} | |
} else if (ytcenter.settings.commentCountryPosition === "last") { | |
container.style.marginLeft = "10px"; | |
if (comment.hasSource) { | |
metadata.insertBefore(container, metadata.lastChild); | |
} else if (!comment.isReply) { | |
if (metadata.children.length > 2) { | |
metadata.insertBefore(container, metadata.children[2]); | |
} else { | |
metadata.appendChild(container); | |
} | |
} else { | |
if (metadata.children.length > 3) { | |
metadata.insertBefore(container, metadata.children[3]); | |
} else { | |
metadata.appendChild(container); | |
} | |
} | |
} | |
}; | |
exports.handleFlagWorker = function(comment){ | |
exports.addFlagPlaceholder(comment); | |
ytcenter.jobs.createWorker(comment.profileId || comment.channelId || comment.googleId, function(args){ | |
try { | |
if (comment.profileId || comment.googleId) { | |
ytcenter.getGooglePlusUserData(comment.profileId || comment.googleId, function(data){ | |
if (data) { | |
comment.country = data; | |
} else { | |
comment && comment.unloadLoadButton && comment.unloadLoadButton(); | |
con.error("[Comment Country] Unknown Location", data); | |
} | |
args.complete(comment.country || null); | |
}); | |
} else if (comment.channelId) { | |
ytcenter.getUserData(comment.channelId, function(data){ | |
if (data) { | |
comment.country = data; | |
} else { | |
comment && comment.unloadLoadButton && comment.unloadLoadButton(); | |
con.error("[Comment Country] Unknown Location", data); | |
} | |
args.complete(comment.country || null); | |
}); | |
} else { | |
comment && comment.unloadLoadButton && comment.unloadLoadButton(); | |
args.complete(null); | |
} | |
} catch (e) { | |
comment && comment.unloadLoadButton && comment.unloadLoadButton(); | |
con.error(e); | |
args.complete(null); | |
} | |
}, function(data){ | |
if (!data) data = "unknown"; | |
if (comment.profileId || comment.channelId) { | |
ytcenter.cache.putItem("profile_country", comment.profileId || comment.channelId, data, 2678400000 /* 31 days */); | |
} | |
comment.country = data; | |
exports.completeFlag(comment, data); | |
}); | |
}; | |
exports.handleFlag = function(comment){ | |
if (comment.flagAdded) return; | |
comment.flagAdded = true; | |
if (comment.country) { | |
exports.completeFlag(comment, comment.country); | |
} else if (ytcenter.settings.commentCountryButtonLoad) { | |
exports.addLoadButton(comment); | |
} else { | |
if (ytcenter.settings.commentCountryLazyLoad) { | |
ytcenter.domEvents.addEvent(comment.element, "enterview", function(){ | |
exports.handleFlagWorker(comment); | |
}, true); | |
} else { | |
exports.handleFlagWorker(comment); | |
} | |
} | |
}; | |
exports.addFlags = function(){ | |
if (!ytcenter.settings.commentCountryEnabled) return; | |
var i; | |
for (i = 0; i < exports.comments.length; i++) { | |
exports.handleFlag(exports.comments[i]); | |
} | |
}; | |
exports.update = function(){ | |
if (!ytcenter.settings.commentCountryEnabled) return; | |
exports.loadComments(); | |
exports.addFlags(); | |
}; | |
exports.setupObserver = function(){ | |
try { | |
observer = ytcenter.mutation.observe(document.getElementById("watch-discussion"), { childList: true, subtree: true }, exports.update); | |
} catch (e) { | |
con.error(e); | |
} | |
}; | |
exports.dispose = function(){ | |
if (observer) { | |
observer.disconnect(); | |
observer = null; | |
} | |
}; | |
exports.setup = function(){ | |
if (!ytcenter.settings.commentCountryEnabled) return; | |
ytcenter.cache.putCategory("profile_country", ytcenter.settings.commentCacheSize); | |
ytcenter.domEvents.setup(); | |
exports.update(); | |
document.body.className += " ytcenter-comments-plus"; | |
ytcenter.events.addEvent("resize-update", function(){ | |
exports.update(); | |
}); | |
exports.setupObserver(); | |
}; | |
return exports; | |
})(); | |
ytcenter.uploaderFlag = (function(){ | |
function init() { | |
if (!ytcenter.settings.uploaderCountryEnabled) return; | |
ytcenter.cache.putCategory("profile_country", ytcenter.settings.commentCacheSize); | |
var userHeader = (ytcenter.feather ? document.getElementById("ud") : document.getElementById("watch7-user-header")), user, id; | |
if (userHeader) { | |
user = (ytcenter.feather ? userHeader.getElementsByTagName("a")[0] : userHeader.getElementsByTagName("a")[1]); | |
id = user.getAttribute("data-ytid"); | |
var country = ytcenter.cache.getItem("profile_country", id); | |
if (country) { | |
addFlag(country.data); | |
} else { | |
work(id); | |
} | |
} | |
} | |
function work(id) { | |
ytcenter.jobs.createWorker(id, function(args){ | |
try { | |
ytcenter.getUserData(id, function(country){ | |
args.complete(country); | |
}); | |
} catch (e) { | |
con.error(e); | |
args.complete(null); | |
} | |
}, function(data){ | |
if (!data) return; | |
if (id) { | |
ytcenter.cache.putItem("profile_country", id, data, 2678400000 /* 31 days */); | |
} | |
addFlag(data); | |
}); | |
} | |
function addFlag(country) { | |
var userHeader = (ytcenter.feather ? document.getElementById("ud") : document.getElementById("watch7-user-header")); | |
var userInfo = userHeader; | |
if (!ytcenter.feather && userHeader && userHeader.getElementsByClassName("yt-user-info").length > 0) { | |
userInfo = userHeader.getElementsByClassName("yt-user-info")[0]; | |
} | |
var separator = userInfo.children[1]; | |
var user = (ytcenter.feather ? userInfo.getElementsByTagName("a")[0] : userInfo.getElementsByTagName("a")[1]); | |
var linebreak = (ytcenter.feather ? userInfo.lastChild : userInfo.getElementsByTagName("br")[0]); | |
var countryContainer = document.createElement("span"); | |
var countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); | |
if (userInfo.getElementsByClassName("country").length > 0) return; | |
countryContainer.className = "country"; | |
if (ytcenter.settings.uploaderCountryShowFlag && ytcenter.flags[country.toLowerCase()]) { | |
var img = document.createElement("img"); | |
img.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
img.className = ytcenter.flags[country.toLowerCase()] + " yt-uix-tooltip"; | |
if (ytcenter.settings.uploaderCountryUseNames) { | |
img.setAttribute("alt", countryName || country); | |
img.setAttribute("title", countryName || country); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
var _countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); | |
img.setAttribute("alt", _countryName || country); | |
img.setAttribute("title", _countryName || country); | |
}); | |
} else { | |
img.setAttribute("alt", country); | |
img.setAttribute("title", country); | |
} | |
countryContainer.appendChild(img); | |
} else { | |
if (ytcenter.settings.uploaderCountryUseNames) { | |
countryContainer.textContent = countryName || country; | |
ytcenter.events.addEvent("language-refresh", function(){ | |
var _countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); | |
countryContainer.textContent = _countryName || country; | |
}); | |
} else { | |
countryContainer.textContent = country; | |
} | |
} | |
countryContainer.style.verticalAlign = "middle"; | |
if (ytcenter.settings.uploaderCountryPosition === "before_username") { | |
countryContainer.style.marginRight = "10px"; | |
userInfo.insertBefore(countryContainer, userInfo.children[0]); | |
} else if (ytcenter.settings.uploaderCountryPosition === "after_username") { | |
if (ytcenter.utils.hasClass(separator, "yt-user-name-icon-verified") || ytcenter.utils.hasClass(separator, "yt-channel-title-icon-verified")) { | |
separator = userInfo.children[2]; | |
} | |
countryContainer.style.marginLeft = "5px"; | |
userInfo.insertBefore(countryContainer, separator); | |
} else if (ytcenter.settings.uploaderCountryPosition === "last") { | |
countryContainer.style.marginLeft = "5px"; | |
if (ytcenter.feather) { | |
userInfo.appendChild(countryContainer); | |
} else { | |
userInfo.insertBefore(countryContainer, linebreak); | |
} | |
} | |
} | |
return { | |
init: init | |
}; | |
})(); | |
ytcenter.jobs = (function(){ | |
var exports = {}, workers = {}, pendingWorkers = [], workingWorkers = [], completedWorkers = [], _max_workers = 20; | |
/* id the id of the worker. | |
action the action function, which will do the job. | |
complete the function which will be called when the job is finished. | |
*** | |
This creates a new worker, which will execute a job. | |
If a worker with the same id is created it will just execute the complete function instead with the previous data. | |
*/ | |
exports.createWorker = function(id, action, complete){ | |
if (id in workers) { | |
if (workers[id].completed) { | |
con.log("[Worker] Job has already been executed once (" + id + ")"); | |
complete(workers[id].data); | |
} else { | |
con.log("[Worker] Job is currently being executed (" + id + ")"); | |
workers[id].completeActions.push(complete); | |
} | |
} else { | |
workers[id] = { | |
completeActions: [ complete ], | |
run: function(){ action(workers[id].args); }, | |
args: { | |
complete: function(data){ | |
con.log("[Worker] Job completed (" + id + ")"); | |
var i; | |
for (i = 0; i < workingWorkers.length; i++) { | |
if (workingWorkers[i] === id) { | |
completedWorkers.push(workingWorkers.splice(i, 1)[0]); | |
break; | |
} | |
} | |
workers[id].completed = true; | |
workers[id].data = data; | |
var i; | |
for (i = 0; i < workers[id].completeActions.length; i++) { | |
workers[id].completeActions[i](data); | |
} | |
exports.run(); | |
}, | |
remove: ytcenter.utils.once(function(){ delete workers[id]; }) | |
}, | |
completed: false | |
}; | |
con.log("[Worker] Addiong new job (" + id + ")"); | |
pendingWorkers.push(id); | |
exports.run(); | |
} | |
}; | |
exports.run = function(){ | |
var id; | |
while ((workingWorkers.length < _max_workers || _max_workers === -1) && pendingWorkers.length > 0) { | |
id = pendingWorkers.splice(0, 1)[0]; | |
workingWorkers.push(id); | |
con.log("[Worker] Executing new job (" + id + ")"); | |
workers[id].run(); | |
} | |
}; | |
exports.getPendingWorkers = function(){ | |
return pendingWorkers; | |
}; | |
exports.getWorkingWorkers = function(){ | |
return workingWorkers; | |
}; | |
exports.getCompletedWorkers = function(){ | |
return completedWorkers; | |
}; | |
return exports; | |
})(); | |
ytcenter.cache = (function(){ | |
function saveChanges() { | |
if (!_timer) { | |
_timer = uw.setTimeout(function(){ | |
_timer = null; | |
ytcenter.saveSettings(); | |
}, 2000); | |
} | |
} | |
var exports = {}, _timer = null; | |
exports.putCategory = function(id, size){ | |
if (!ytcenter.settings.cache) ytcenter.settings.cache = {}; | |
if (ytcenter.settings.cache[id] && ytcenter.settings.cache[id].size === size) return; | |
if (ytcenter.settings.cache[id]) { | |
ytcenter.settings.cache[id].size = size; | |
} else { | |
ytcenter.settings.cache[id] = { size: size, items: [] }; | |
} | |
exports.checkCache(); | |
saveChanges(); | |
}; | |
exports.getCategory = function(id){ | |
if (!ytcenter.settings.cache) ytcenter.settings.cache = {}; | |
return ytcenter.settings.cache[id] || null; | |
}; | |
exports.getItem = function(catId, id){ | |
if (!ytcenter.settings.cache) ytcenter.settings.cache = {}; | |
var cat = exports.getCategory(catId), i; | |
if (!cat) return false; | |
for (i = 0; i < cat.items.length; i++) { | |
if (cat.items[i].i === id) | |
return { id: cat.items[i].i, categoryId: catId, data: cat.items[i].d, expires: cat.items[i].e, lastUpdated: cat.items[i].l, index: i }; | |
} | |
return null; | |
}; | |
/** | |
* catId : the unique id of the category the item is in. | |
* id : the unique id of the item. | |
* data : the data of the item. | |
* expires : the milliseconds after the last update date. If the sum of expires and the lastUpdate is less than the date the item will be removed. | |
*/ | |
exports.putItem = function(catId, id, data, expires){ | |
if (!ytcenter.settings.cache) ytcenter.settings.cache = {}; | |
exports.checkCache(); | |
var cat = exports.getCategory(catId), item; | |
if (!cat) throw "[Cache] Category " + catId + " doesn't exist!"; | |
item = exports.getItem(catId, id); | |
if (item) { | |
cat.items[item.index].d = data; | |
cat.items[item.index].e = expires; | |
cat.items[item.index].l = +new Date; | |
} else { | |
item = { i: id, d: data, e: expires, l: +new Date }; | |
if (cat.items.length >= cat.size) cat.items.shift(); | |
cat.items.push(item); | |
} | |
saveChanges(); | |
}; | |
/* Find expired items and removes them. */ | |
exports.checkCache = function(){ | |
if (!ytcenter.settings.cache) return; | |
var key, i, now = +new Date, save = false; | |
for (key in ytcenter.settings.cache) { | |
if (ytcenter.settings.cache.hasOwnProperty(key)) { | |
for (i = 0; i < ytcenter.settings.cache[key].items.length; i++) { | |
if (ytcenter.settings.cache[key].items[i].l + ytcenter.settings.cache[key].items[i].e < now) { | |
save = true; | |
ytcenter.settings.cache[key].items.splice(i, 1); | |
i--; | |
} | |
} | |
} | |
} | |
saveChanges(); | |
}; | |
return exports; | |
})(); | |
ytcenter.getUserData = function(userId, callback) { | |
var apikey = getAPIKey(); | |
ytcenter.utils.browser_xhr({ | |
url: "https://www.googleapis.com/youtube/v3/channels?part=snippet&id=" + encodeURIComponent(userId) + "&key=" + encodeURIComponent(apikey), | |
method: "GET", | |
onload: function(r) { | |
var data = null; | |
try { | |
data = JSON.parse(r.responseText); | |
} catch (e) { | |
con.error("[getUserData] Error:", e); | |
} | |
var country = null; | |
if (data) { | |
if (data.items && data.items.length > 0 && data.items[0] && data.items[0].snippet) { | |
country = data.items[0].snippet.country; | |
con.log("[getUserData] Success. userID: " + userId + " Country: " + country, data); | |
} else if (data.error) { | |
con.error("[getUserData] Error:", data.error) | |
} | |
} | |
callback(country); | |
}, | |
onerror: function(response){ | |
try { | |
var data = JSON.parse(r.responseText); | |
con.error("[getUserData] Error:", data.error) | |
} catch (e) { | |
con.error("[getUserData] Error: " + response.responseText); | |
} | |
callback(null); | |
} | |
}); | |
}; | |
ytcenter.getGooglePlusUserData = function(oId, callback) { | |
function handleFinalUrl(url) { | |
var userId = null; | |
if (url.indexOf("youtube.com/channel/") !== -1) { | |
userId = url.split("youtube.com/channel/"); | |
if (userId && userId[1]) | |
ytcenter.getUserData(userId[1], callback); | |
} else if (url.indexOf("youtube.com/user/") !== -1) { | |
userId = url.split("youtube.com/user/"); | |
if (userId && userId[1]) | |
ytcenter.getUserData(userId[1], callback); | |
} else { | |
con.error("[Comments getGooglePlusUserData] Final URL: " + r.finalUrl); | |
callback(null); | |
} | |
} | |
ytcenter.utils.xhr({ | |
url: ytcenter.protocol + "www.youtube.com/profile_redirector/" + oId, | |
method: "GET", | |
onload: function(r){ | |
try { | |
if (!r.finalUrl || r.finalUrl === "") { | |
handleFinalUrl(ytcenter.utils.getContentByTags(r.responseText, "<meta property=\"og:url\" content=\"", "\">")); | |
} else { | |
handleFinalUrl(r.finalUrl); | |
} | |
} catch (e) { | |
con.error("[Comments getGooglePlusUserData] Couldn't parse data from " + ytcenter.protocol + "www.youtube.com/profile_redirector/" + oId); | |
con.error(r); | |
con.error(e); | |
callback(null); | |
} | |
}, | |
onerror: function(){ | |
con.error("[Comments getGooglePlusUserData] Couldn't fetch data from " + ytcenter.protocol + "www.youtube.com/profile_redirector/" + oId); | |
callback(null); | |
} | |
}); | |
}; | |
ytcenter.getPage = function(url){ | |
url = url || loc.href; | |
var pathname = (url && url.split("youtube.com")[1]) || loc.pathname; | |
if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/watch\?/)) { | |
ytcenter.page = "watch"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/all_comments\?/)) { | |
ytcenter.page = "all_comments"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/edit\?/)) { | |
ytcenter.page = "edit"; | |
} else if (!!url.match(/^http(s)?:\/\/((apis\.google\.com)|(plus\.googleapis\.com))\/([0-9a-zA-Z-_\/]+)\/widget\/render\/comments\?/)) { | |
ytcenter.page = "comments"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\//) && (loc.pathname === "/" || loc.pathname === "/feed/what_to_watch")) { | |
ytcenter.page = "feed_what_to_watch"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/ZZZembed\//) || !!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/watch_popupZZZ\?\//)) { | |
ytcenter.page = "embed"; | |
} else if ( document && | |
document.body && | |
document.body.innerHTML.indexOf("data-swf-config") !== -1 && | |
document.body.innerHTML.indexOf("movie_player") !== -1 && | |
document.body.innerHTML.indexOf("youtube.com/v/") !== -1 && | |
document.body.innerHTML.indexOf("flashvars=") !== -1) { | |
ytcenter.page = "channel"; | |
} else if (document.getElementById("page") && ytcenter.utils.hasClass(document.getElementById("page"), "channel")) { | |
ytcenter.page = "channel"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/(user|channel|u|c)\//)) { | |
ytcenter.page = "channel"; | |
} else if (!!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\//)) { | |
if (loc.pathname === "/results") { | |
ytcenter.page = "search"; | |
} else { | |
ytcenter.page = "other"; | |
} | |
} | |
return ytcenter.page; | |
}; | |
ytcenter.pageReadinessListener = (function(){ | |
function call(event){ | |
for (i = 0; i < events.length; i++) { | |
if (events[i].event === event) { | |
con.log("[PageReadinessListener] Calling => " + events[i].event); | |
for (j = 0; j < events[i].callbacks.length; j++) { | |
events[i].callbacks[j](); | |
} | |
} | |
} | |
} | |
function addEventListener(event, callback){ | |
var i; | |
for (i = 0; i < events.length; i++) { | |
if (events[i].event === event) { | |
if (!events[i].callbacks) events[i].callbacks = []; | |
events[i].callbacks.push(callback); | |
return; | |
} | |
} | |
} | |
function update(){ | |
var i, j, page = ytcenter.getPage(loc.href); | |
if (ytcenter.pageReadinessListener.waitfor) { | |
if (!ytcenter.pageReadinessListener.waitfor()) return; | |
} | |
for (i = 0; i < events.length; i++) { | |
if (events[i].called) continue; | |
if (events[i].test && !events[i].test()) break; | |
events[i].called = true; | |
if (events[i].event === "stopInterval") { | |
con.log("[PageReadinessListener] Stopping interval"); | |
uw.clearInterval(preTester); | |
ytcenter.utils.removeEventListener(document, "readystatechange", update, true); | |
ytcenter.utils.removeEventListener(document, "DOMContentLoaded", update, true); | |
events = null; | |
preTester = null; | |
preTesterInterval = null; | |
update = null; | |
return; | |
} else if (events[i].event === "startInterval") { | |
con.log("[PageReadinessListener] Starting interval"); | |
uw.clearInterval(preTester); // Just to make sure that only one instance is running. | |
preTester = uw.setInterval(function(){ | |
update(); | |
}, preTesterInterval); | |
} else { | |
con.log("[PageReadinessListener] At event => " + events[i].event, page); | |
events[i].called = true; | |
for (j = 0; j < events[i].callbacks.length; j++) { | |
events[i].callbacks[j](page); | |
} | |
} | |
} | |
}; | |
function setup(){ | |
ytcenter.utils.addEventListener(document, "readystatechange", update, true); | |
ytcenter.utils.addEventListener(document, "DOMContentLoaded", update, true); | |
preTester = uw.setInterval(function(){ | |
update(); | |
}, preTesterInterval); | |
update(); | |
} | |
var events = [ | |
{ | |
event: "headerInitialized", | |
test: function(){ | |
if (document && document.getElementsByTagName && document.getElementsByTagName("head")[0]) | |
return true; | |
return false; | |
}, | |
called: false, | |
callbacks: [] | |
}, { | |
event: "bodyInitialized", | |
test: function(){ | |
if (document && document.body && (document.body.className !== "" || ytcenter.feather)) | |
return true; | |
return false; | |
}, | |
called: false, | |
callbacks: [] | |
}, { | |
event: "bodyInteractive", test: function(){ | |
if (document.readyState === "interactive" || document.readyState === "complete") | |
return true; | |
return false; | |
}, | |
called: false, | |
callbacks: [] | |
}, { | |
event: "bodyComplete", test: function(){ | |
if (document.readyState === "complete") | |
return true; | |
return false; | |
}, | |
called: false, | |
callbacks: [] | |
}, { | |
event: "stopInterval", | |
called: false, | |
callbacks: [] | |
} | |
]; | |
var preTester; | |
var preTesterInterval = 75; | |
return { | |
setup: setup, | |
update: update, | |
addEventListener: addEventListener, | |
call: call, | |
}; | |
})(); | |
ytcenter.thumbnail = (function(){ | |
function getPlaylistVideoThumbs() { | |
var pt = document.getElementById("watch7-playlist-tray"), | |
pt2 = document.getElementById("guide"), | |
pt3 = document.getElementById("watch-appbar-playlist"), | |
a = [], b, i; | |
if (pt) { | |
b = pt.getElementsByClassName("video-thumb"); | |
for (i = 0; i < b.length; i++) { | |
a.push(b[i]); | |
} | |
} | |
if (pt2) { | |
b = pt2.getElementsByClassName("video-thumb"); | |
for (i = 0; i < b.length; i++) { | |
a.push(b[i]); | |
} | |
} | |
if (pt3) { | |
b = pt3.getElementsByClassName("video-thumb"); | |
for (i = 0; i < b.length; i++) { | |
a.push(b[i]); | |
} | |
} | |
return a; | |
} | |
function handleVideoThumbs(videoThumb, videoElement) { | |
var maxIterations = 10; | |
var linkRegex = /v=([a-zA-Z0-9-_]+)/; | |
var linkRegex2 = /index=([0-9]+)/; | |
var linkRegex3 = /video_ids=([0-9a-zA-Z-_%]+)/; | |
var i = null; | |
var a = null; | |
var id = null; | |
var data = null; | |
var cacheData = null; | |
var wrapper = null; | |
var rgx = null; | |
var index = null; | |
if (videoElement.tagName === "A") { | |
wrapper = videoElement; | |
} else if (videoElement.parentNode.tagName === "A") { | |
wrapper = videoElement.parentNode; | |
} else { | |
wrapper = null; | |
} | |
if (wrapper) { | |
if (wrapper.href.match(linkRegex)) { | |
rgx = linkRegex.exec(wrapper.href); | |
if (rgx && rgx[1]) id = rgx[1]; | |
else return null; | |
cacheData = getDataCacheById(id); | |
data = {id: id, content: videoElement, wrapper: wrapper, videoThumb: videoThumb}; | |
if (cacheData) { | |
if (cacheData.stream) data.stream = cacheData.stream; | |
if (cacheData.likes) data.likes = cacheData.likes; | |
if (cacheData.dislikes) data.dislikes = cacheData.dislikes; | |
} | |
} else if (wrapper.href.match(linkRegex3)) { | |
rgx = linkRegex2.exec(wrapper.href); | |
if (rgx && rgx[1]) index = parseInt(rgx[1]); | |
else index = 0; | |
rgx = linkRegex3.exec(wrapper.href); | |
if (rgx && rgx[1]) id = rgx[1]; | |
else return null; | |
if (id.split("%2C").length > 0 && id.split("%2C")[index]) id = id.split("%2C")[index]; | |
else return null; | |
cacheData = getDataCacheById(id); | |
data = {id: id, content: videoElement, wrapper: wrapper, videoThumb: videoThumb}; | |
if (cacheData) { | |
if (cacheData.stream) data.stream = cacheData.stream; | |
if (cacheData.likes) data.likes = cacheData.likes; | |
if (cacheData.dislikes) data.dislikes = cacheData.dislikes; | |
} | |
} | |
if (data) { | |
a = wrapper; | |
for (i = 0; i < maxIterations; i++) { | |
a = a.parentNode; | |
if (!a) break; // At the top of the tree | |
if (a.tagName === "LI") { // We found it guys. Great job. | |
data.itemWrapper = a; | |
break; | |
} | |
} | |
if (ytcenter.utils.hasClass(videoThumb, "yt-uix-simple-thumb-wrap")) { | |
data.content = videoThumb; | |
} | |
var img = videoThumb.getElementsByTagName("img"); | |
if (img && img.length > 0 && img[0]) { | |
data.thumbnailImage = img[0]; | |
} | |
return data; | |
} | |
} | |
return null; | |
} | |
function inArray_(arr, item) { | |
for (var i = 0; i < arr.length; i++) { | |
if (arr[i].wrapper === item.wrapper) { | |
return true; | |
} | |
} | |
return false; | |
} | |
function getVideoThumbs() { | |
var userHeader = document.getElementById("watch7-user-header"); // Improved performance by moving this part out of the for loop | |
var arr = ytcenter.utils.toArray(document.getElementsByClassName("video-thumb")).concat(ytcenter.utils.toArray(document.getElementsByClassName("yt-uix-simple-thumb-wrap"))); | |
var videos = []; | |
var playlistVideoThumbs = getPlaylistVideoThumbs(); | |
var i; | |
for (var i = 0, len = arr.length; i < len; i++) { | |
if (ytcenter.utils.inArray(playlistVideoThumbs, arr[i]) || (userHeader && ytcenter.utils.isParent(userHeader, arr[i]))) continue; | |
var data = handleVideoThumbs(arr[i], arr[i].parentNode); | |
if (data && !inArray_(videos, data)) { | |
videos.push(data); | |
} | |
} | |
return videos; | |
} | |
function loadVideoConfig(item, options, callback) { | |
if (typeof options === "function") { | |
callback = options; | |
options = {}; | |
} | |
options.spflink = typeof options.spflink === "boolean" ? options.spflink : true; | |
if (item.stream && item.storyboard) { | |
callback(item.stream, item.storyboard); | |
} else { | |
var spflink = options.spflink, | |
url = "//www.youtube.com/watch?v=" + item.id + (spflink ? "&spf=navigate" : ""); | |
var headers = {}; | |
if (window.ytspf && window.ytspf.config && window.ytspf.config["experimental-request-headers"]) { | |
headers = window.ytspf.config["experimental-request-headers"]; | |
} | |
headers["X-SPF-previous"] = window.location.href; | |
headers["X-SPF-referer"] = window.location.href; | |
if (loc.href.indexOf("https://") === 0) { | |
url = "https:" + url; | |
} else { | |
url = "http:" + url; | |
} | |
ytcenter.utils.xhr({ | |
url: url, | |
method: "GET", | |
headers: headers, | |
onload: function(r) { | |
var cfg = null; | |
var errorType = "unknown"; | |
try { | |
try { | |
if (spflink) { | |
var parts = JSON.parse(r.responseText); | |
if (ytcenter.utils.isArray(parts)) { | |
for (var i = 0, len = parts.length; i < len; i++) { | |
var part = parts[i]; | |
if (part && part.data && part.data.swfcfg) { | |
cfg = part.data.swfcfg; | |
break; | |
} | |
} | |
if (!cfg) throw "Player configurations not found in spf."; | |
} else if (parts["reload"] === "now") { | |
loadVideoConfig(item, { spflink: false }, callback); | |
return; | |
} | |
} else { | |
cfg = r.responseText.split("<script>var ytplayer = ytplayer || {};ytplayer.config = ")[1].split(";</script>")[0].split(";ytplayer.load")[0]; | |
cfg = JSON.parse(cfg); | |
} | |
} catch (e) { | |
con.error(e); | |
if (r.responseText.indexOf("flashvars=\"") !== -1) { | |
var a = r.responseText.split("flashvars=\"")[1].split("\"")[0].replace(/&/g, "&").replace(/"/g, "\"").split("&"), | |
i, b; | |
cfg = {args: {}}; | |
for (i = 0; i < a.length; i++) { | |
b = a[i].split("="); | |
cfg.args[decodeURIComponent(b[0])] = decodeURIComponent(b[1]); | |
} | |
} else if (r.responseText.indexOf("new yt.player.Application('p', {") !== -1) { | |
cfg = {}; | |
cfg.args = r.responseText.split("new yt.player.Application('p', ")[1].split(");var fbetatoken")[0]; | |
cfg.args = JSON.parse(cfg.args); | |
} | |
} | |
item.stream = ytcenter.player.getBestStream(ytcenter.parseStreams(cfg.args), (ytcenter.settings.videoThumbnailQualitySeparated ? (ytcenter.settings.dashPlayback ? 1 : 0) : -1)); | |
if (!item.stream) { | |
if (cfg && cfg.args && cfg.args.ypc_module && cfg.args.ypc_vid) { | |
item.stream = { | |
quality: "ondemand" | |
}; | |
} | |
} | |
if (cfg && cfg.args) { | |
item.storyboard = cfg.args.storyboard_spec || cfg.args.live_storyboard_spec; | |
} | |
try { | |
delete item.stream.fallback_host; | |
delete item.stream.sig; | |
delete item.stream.flashVersion; | |
delete item.stream.url; | |
} catch (e) { | |
con.error(e); | |
} | |
try { | |
if (isInCache(item)) { | |
updateItemInCache(item); | |
} else { | |
addNewDataToCache(item); | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
if (item.stream) { | |
callback(item.stream, item.storyboard); | |
} else { | |
callback("error", null, "Error!"); | |
} | |
} catch (e) { | |
var msg = ""; | |
if (e === "unavailable") { | |
msg = "Video Unavailable!"; | |
} else { | |
if (r.responseText.indexOf("Too many") !== -1) { | |
msg = "Too many requests!"; | |
} else { | |
msg = "Error!"; | |
con.error(e); | |
con.error(cfg); | |
try { | |
con.error(JSON.parse(r.responseText)); | |
} catch (e) { | |
con.error(r.responseText); | |
} | |
} | |
} | |
con.error("[VideoThumbnail Quality] IO Error => " + msg); | |
callback("error", null, msg); | |
} | |
}, | |
onerror: function(){ | |
var msg = "Connection failed!"; | |
con.error("[VideoThumbnail Quality] IO Error => " + msg); | |
callback("error", null, msg); | |
} | |
}); | |
} | |
} | |
function loadRatings(items, callback) { | |
var apikey = getAPIKey(); | |
var ids = []; | |
var ids_item = []; | |
var pendingItems = []; | |
for (var i = 0; i < items.length; i++) { | |
if (!items[i].processing && !ytcenter.utils.inArray(processedVideoIds, items[i].id)) { | |
if ((!items[i].likes || !items[i].dislikes)) { | |
processedVideoIds.push(items[i].id); | |
items[i].processing = true; | |
ids_item.push(items[i]); | |
ids.push(items[i].id); | |
} | |
pendingItems.push(items[i]); | |
} | |
} | |
if (ids.length > 0) { | |
var url = "https://www.googleapis.com/youtube/v3/videos?part=statistics&id=" + encodeURIComponent(ids.join(",")) + "&key=" + encodeURIComponent(apikey); | |
ytcenter.utils.browser_xhr({ | |
url: url, | |
method: "GET", | |
onload: function(detail){ | |
try { | |
var data = JSON.parse(detail.responseText); | |
for (var i = 0; i < data.items.length; i++) { | |
try { | |
var statistics = data.items[i].statistics; | |
var index = ytcenter.utils.indexOf_(ids, data.items[i].id); | |
var item = ids_item[index]; | |
item.likes = parseInt(statistics ? statistics.likeCount : 0); | |
item.dislikes = parseInt(statistics ? statistics.dislikeCount : 0); | |
if (isInCache(item)) { | |
updateItemInCache(item); | |
} else { | |
addNewDataToCache(item); | |
} | |
} catch (e) { | |
con.error("Internal error", e); | |
} | |
} | |
callback(pendingItems); | |
} catch (e) { | |
var msg = ""; | |
if (e === "unavailable") { | |
msg = "Unavailable!"; | |
} else { | |
if (r.responseText.indexOf("<errors xmlns='http://schemas.google.com/g/2005'><error><domain>GData</domain>") === 0) { | |
msg = "Error!"; | |
if (r.responseText.indexOf("<internalReason>") !== -1 && r.responseText.indexOf("</internalReason>") !== -1) { | |
msg = ytcenter.utils.unescapeXML(r.responseText.split("<internalReason>")[1].split("</internalReason>")[0]) + "!"; | |
} | |
} else if (r.responseText.indexOf("<code>too_many_recent_calls</code>") !== -1 && r.responseText.indexOf("<domain>yt:quota</domain>") !== -1) { | |
msg = "Too many requests!"; | |
} else { | |
msg = "Error!"; | |
con.error(e); | |
try { | |
con.error(JSON.parse(r.responseText)); | |
} catch (e) { | |
con.error(r.responseText); | |
} | |
} | |
} | |
con.error("[VideoThumbnail Ratings] IO Error => " + msg); | |
callback("error", msg); | |
} | |
}, | |
onerror: function(){ | |
var msg = "Connection failed!"; | |
con.error("[VideoThumbnail Quality] IO Error => " + msg); | |
callback("error", msg); | |
} | |
}); | |
} else { | |
callback(pendingItems); | |
} | |
} | |
function loadVideoData(item, callback) { | |
if (item.likes && item.dislikes) { | |
callback(item.likes, item.dislikes); | |
} else if (item.id) { | |
var apikey = getAPIKey(); | |
var url = "https://www.googleapis.com/youtube/v3/videos?part=statistics&id=" + encodeURIComponent(item.id) + "&key=" + encodeURIComponent(apikey); | |
ytcenter.utils.browser_xhr({ | |
url: url, | |
method: "GET", | |
onload: function(r){ | |
try { | |
if (!r.responseText) throw "unavailable"; | |
var videoData = JSON.parse(r.responseText).items[0]; | |
var statistics = videoData.statistics; | |
item.likes = parseInt(statistics ? statistics.likeCount : 0); | |
item.dislikes = parseInt(statistics ? statistics.dislikeCount : 0); | |
if (isInCache(item)) { | |
updateItemInCache(item); | |
} else { | |
addNewDataToCache(item); | |
} | |
callback(item.likes, item.dislikes); | |
} catch (e) { | |
var msg = ""; | |
if (e === "unavailable") { | |
msg = "Unavailable!"; | |
} else { | |
if (r.responseText.indexOf("<errors xmlns='http://schemas.google.com/g/2005'><error><domain>GData</domain>") === 0) { | |
msg = "Error!"; | |
if (r.responseText.indexOf("<internalReason>") !== -1 && r.responseText.indexOf("</internalReason>") !== -1) { | |
msg = ytcenter.utils.unescapeXML(r.responseText.split("<internalReason>")[1].split("</internalReason>")[0]) + "!"; | |
} | |
} else if (r.responseText.indexOf("<code>too_many_recent_calls</code>") !== -1 && r.responseText.indexOf("<domain>yt:quota</domain>") !== -1) { | |
msg = "Too many requests!"; | |
} else { | |
msg = "Error!"; | |
con.error(e); | |
try { | |
con.error(JSON.parse(r.responseText)); | |
} catch (e) { | |
con.error(r.responseText); | |
} | |
} | |
} | |
con.error("[VideoThumbnail Ratings] IO Error => " + msg); | |
callback("error", msg); | |
} | |
}, | |
onerror: function(){ | |
var msg = "Connection failed!"; | |
con.error("[VideoThumbnail Quality] IO Error => " + msg); | |
callback("error", msg); | |
} | |
}); | |
} | |
} | |
function appendRatingBar(item, likes, dislikes) { | |
try { | |
var total = likes + dislikes, | |
sparkBars = document.createElement("div"), | |
sparkBarLikes = document.createElement("div"), | |
sparkBarDislikes = document.createElement("div"), | |
barLength; | |
sparkBars.className = "video-extras-sparkbars" | |
+ (ytcenter.settings.videoThumbnailRatingsBarVisible === "show_hover" ? " ytcenter-video-thumb-show-hover" : "") | |
+ (ytcenter.settings.videoThumbnailRatingsBarVisible === "hide_hover" ? " ytcenter-video-thumb-hide-hover" : ""); | |
sparkBars.style.height = ytcenter.settings.videoThumbnailRatingsBarHeight + "px"; | |
if (!ytcenter.utils.hasClass(item.videoThumb, "yt-thumb-fluid") && item.videoThumb.className.match(/yt-thumb-[0-9]+/)) { | |
barLength = /yt-thumb-([0-9]+)/.exec(item.videoThumb.className)[1] + "px"; | |
} else if (item.videoThumb.style.width && parseInt(item.videoThumb.style.width) > 0) { | |
barLength = item.videoThumb.style.width; | |
} else { | |
barLength = "100%"; | |
} | |
sparkBarLikes.className = "video-extras-sparkbar-likes"; | |
sparkBarLikes.style.background = ytcenter.settings.videoThumbnailRatingsBarLikesColor; | |
sparkBarLikes.style.height = ytcenter.settings.videoThumbnailRatingsBarHeight + "px"; | |
sparkBarDislikes.className = "video-extras-sparkbar-dislikes"; | |
sparkBarDislikes.style.height = ytcenter.settings.videoThumbnailRatingsBarHeight + "px"; | |
if (likes === "error") { | |
sparkBarDislikes.style.background = "#BF3EFF"; | |
total = 1; | |
likes = 0; | |
dislikes = 1; | |
} else if (total > 0) { | |
sparkBarDislikes.style.background = ytcenter.settings.videoThumbnailRatingsBarDislikesColor; | |
} else { | |
sparkBarDislikes.style.background = ytcenter.settings.videoThumbnailRatingsBarDefaultColor; | |
likes = 0; | |
dislikes = 1; | |
total = 1; | |
} | |
sparkBars.appendChild(sparkBarLikes); | |
sparkBars.appendChild(sparkBarDislikes); | |
sparkBars.style.position = "absolute"; | |
switch (ytcenter.settings.videoThumbnailRatingsBarPosition) { | |
case "top": | |
sparkBars.style.top = "0px"; | |
sparkBars.style.left = "0px"; | |
sparkBarLikes.style.width = (likes/total*100) + "%"; | |
sparkBarDislikes.style.width = (dislikes/total*100) + "%"; | |
sparkBars.style.width = barLength; | |
break; | |
case "bottom": | |
sparkBars.style.bottom = "0px"; | |
sparkBars.style.left = "0px"; | |
sparkBarLikes.style.width = (likes/total*100) + "%"; | |
sparkBarDislikes.style.width = (dislikes/total*100) + "%"; | |
sparkBars.style.width = barLength; | |
break; | |
case "left": | |
sparkBars.style.top = "0px"; | |
sparkBars.style.left = "0px"; | |
sparkBarLikes.style.height = (likes/total*100) + "%"; | |
sparkBarDislikes.style.height = (dislikes/total*100) + "%"; | |
sparkBarLikes.style.width = "2px"; | |
sparkBarDislikes.style.width = "2px"; | |
sparkBarLikes.style.cssFloat = "none"; | |
sparkBarDislikes.style.cssFloat = "none"; | |
sparkBars.style.height = "100%"; | |
break; | |
case "right": | |
sparkBars.style.top = "0px"; | |
sparkBars.style.right = "0px"; | |
sparkBarLikes.style.height = (likes/total*100) + "%"; | |
sparkBarDislikes.style.height = (dislikes/total*100) + "%"; | |
sparkBarLikes.style.width = "2px"; | |
sparkBarDislikes.style.width = "2px"; | |
sparkBarLikes.style.cssFloat = "none"; | |
sparkBarDislikes.style.cssFloat = "none"; | |
sparkBars.style.height = "100%"; | |
break; | |
} | |
item.content.appendChild(sparkBars); | |
} catch (e) { | |
con.error("[Id=" + item.id + "] Likes: " + likes + ", " + dislikes); | |
con.error(e); | |
} | |
} | |
function appendRatingCount(item, likes, dislikes) { | |
try { | |
var numLikesDislikes = document.createElement("span"), | |
likesCount = document.createElement("span"), | |
dislikesCount = document.createElement("span"), | |
likeIcon = document.createElement("div"), | |
dislikeIcon = document.createElement("div"); | |
numLikesDislikes.className = "video-extras-likes-dislikes" | |
+ (ytcenter.settings.videoThumbnailRatingsCountVisible === "show_hover" ? " ytcenter-video-thumb-show-hover" : "") | |
+ (ytcenter.settings.videoThumbnailRatingsCountVisible === "hide_hover" ? " ytcenter-video-thumb-hide-hover" : "") | |
+ " ytcenter-thumbnail-ratingcount"; | |
numLikesDislikes.style.background = "#000"; | |
numLikesDislikes.style.opacity = "0.75"; | |
numLikesDislikes.style.filter = "alpha(opacity=75)"; | |
numLikesDislikes.style.padding = "0 4px"; | |
numLikesDislikes.style.lineHeight = "14px"; | |
numLikesDislikes.style.fontWeight = "bold"; | |
numLikesDislikes.style.zoom = "1"; | |
if (likes === "error") { | |
numLikesDislikes.style.color = "#fff"; | |
numLikesDislikes.style.verticalAlign = "middle"; | |
numLikesDislikes.style.fontSize = "11px"; | |
numLikesDislikes.appendChild(document.createTextNode(dislikes)); | |
} else { | |
likesCount.className = "likes-count"; | |
likesCount.style.marginRight = "4px"; | |
likesCount.style.color = "#fff"; | |
likesCount.style.verticalAlign = "middle"; | |
likesCount.style.fontSize = "11px"; | |
likesCount.textContent = ytcenter.utils.number1000Formating(likes); | |
dislikesCount.className = "dislikes-count"; | |
dislikesCount.style.color = "#fff"; | |
dislikesCount.style.verticalAlign = "middle"; | |
dislikesCount.style.fontSize = "11px"; | |
dislikesCount.textContent = ytcenter.utils.number1000Formating(dislikes); | |
if (ytcenter.utils.hasClass(item.videoThumb, "yt-thumb-120") || ytcenter.utils.hasClass(item.videoThumb, "yt-thumb-106")) { | |
likesCount.style.fontSize = "11px"; | |
dislikesCount.style.fontSize = "11px"; | |
} | |
likeIcon.className = "ytcenter-icon-thumbs-like"; // icon-watch-stats-like | |
likeIcon.setAttribute("alt", "Like"); | |
likeIcon.style.position = "relative"; | |
likeIcon.style.marginRight = "2px"; | |
likeIcon.style.marginTop = "4px"; | |
likeIcon.style.top = "-2px"; | |
likeIcon.style.verticalAlign = "middle"; | |
dislikeIcon.className = "ytcenter-icon-thumbs-dislike"; // icon-watch-stats-dislike | |
dislikeIcon.setAttribute("alt", "Dislike"); | |
dislikeIcon.style.position = "relative"; | |
dislikeIcon.style.marginRight = "2px"; | |
dislikeIcon.style.marginTop = "4px"; | |
dislikeIcon.style.top = "-2px"; | |
dislikeIcon.style.verticalAlign = "middle"; | |
numLikesDislikes.appendChild(likeIcon); | |
numLikesDislikes.appendChild(likesCount); | |
numLikesDislikes.appendChild(dislikeIcon); | |
numLikesDislikes.appendChild(dislikesCount); | |
} | |
numLikesDislikes.style.position = "absolute"; | |
item.content.className += " ytcenter-thumbnail-ratingcount-pos-" + ytcenter.settings.videoThumbnailRatingsCountPosition; | |
item.content.appendChild(numLikesDislikes); | |
} catch (e) { | |
con.error("[Id=" + item.id + "] Likes: " + likes + ", " + dislikes); | |
con.error(e); | |
} | |
} | |
var addedThumbnails = []; | |
function appendAnimatedThumbnail(item, storyboard, errorMessage) { | |
function preload(images) { | |
var i, img; | |
for (i = 0; i < images.length; i++) { | |
img = new Image(); | |
img.src = images[i]; | |
} | |
} | |
function preloadNextMosaic(frame) { | |
if (level) { | |
var nextMosaic = level.getMosaic(frame) + 1; | |
if (preloadURLS.length <= nextMosaic || nextMosaic < 0) { | |
nextMosaic = 0; | |
} | |
if (!preloaded[nextMosaic]) { | |
preload([preloadURLS[nextMosaic]]); | |
con.log("[Animated Thumbnail] Preloaded " + preloadURLS[nextMosaic]); | |
preloaded[nextMosaic] = true; | |
} | |
} else { | |
frame += 1; | |
if (frame > 3 || frame < 1) frame = 1; | |
if (!preloadedDefaultImgs[frame - 1]) { | |
preload([urlTemplate.replace("$N", frame)]); | |
con.log("[Animated Thumbnail] Preloaded " + urlTemplate.replace("$N", frame)); | |
preloadedDefaultImgs[frame - 1] = true; | |
} | |
} | |
} | |
function mouseover() { | |
function moi() { | |
if (level) { | |
a.src = "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"; | |
a.parentNode.style.backgroundColor = "#000000"; | |
if (frame >= level.frames) frame = 0; | |
rect = level.getRect(frame, box); | |
a.style.width = rect.width + "px"; | |
a.style.height = rect.height + "px"; | |
a.style.top = "0px"; | |
a.style.backgroundSize = rect.imageWidth + "px " + rect.imageHeight + "px"; | |
a.style.backgroundImage = "URL(" + level.getURL(frame) + ")"; | |
a.style.backgroundPosition = -rect.x + "px " + -rect.y + "px"; | |
preloadNextMosaic(frame); | |
} else { | |
if (frame > 3 || frame < 1) frame = 1; | |
a.src = urlTemplate.replace("$N", frame); | |
preloadNextMosaic(frame); | |
} | |
if (ytcenter.settings.videoThumbnailAnimationShuffle) { | |
if (level) { | |
frame = Math.round(Math.random()*(level.frames - 1)); | |
} else { | |
frame = Math.round(Math.random()*2) + 1; | |
} | |
} else { | |
frame++; | |
} | |
} | |
preloadNextMosaic(frame - 1); | |
timer2 = uw.setTimeout(function(){ | |
if (level) { | |
timer = uw.setInterval(moi, ytcenter.settings.videoThumbnailAnimationInterval); | |
} else { | |
urlTemplate = originalImage.replace(/\/(mq)?default\.jpg$/, "/$N.jpg"); | |
timer = uw.setInterval(moi, ytcenter.settings.videoThumbnailAnimationFallbackInterval); | |
} | |
moi(); | |
}, ytcenter.settings.videoThumbnailAnimationDelay); | |
} | |
function mouseout() { | |
uw.clearInterval(timer); | |
uw.clearTimeout(timer2); | |
a.src = originalImage; | |
a.style.backgroundSize = ""; | |
a.style.backgroundImage = ""; | |
a.style.backgroundPosition = ""; | |
a.style.width = ""; | |
a.style.height = ""; | |
a.style.top = ""; | |
a.parentNode.style.backgroundColor = ""; | |
frame = 0; | |
} | |
if (item && item.wrapper) { | |
if (ytcenter.utils.inArray(addedThumbnails, item.wrapper)) { | |
return; | |
} else { | |
addedThumbnails.push(item.wrapper); | |
} | |
} else { | |
return; | |
} | |
try { | |
var a = item.wrapper.getElementsByTagName("img")[0], | |
b = ytcenter.player.parseThumbnailStream(storyboard || ""), | |
originalImage = a.getAttribute("data-thumb") || a.src, | |
timer, timer2, frame = 0, level, i, urlTemplate, | |
box = { width: a.offsetWidth, height: 0 }, rect, | |
preloaded = [], preloadURLS = null, preloadedDefaultImgs = [false, false, false]; | |
if (b.levels.length > 0) { | |
for (i = 0; i < b.levels.length; i++) { | |
if (!level) level = b.levels[i]; | |
else if (b.levels[i].width > level.width) | |
level = b.levels[i]; | |
} | |
} | |
if (level) { | |
preloadURLS = level.getURLS(); | |
for (i = 0; i < preloadURLS.length; i++) { | |
preloaded.push(false); | |
} | |
} else { | |
urlTemplate = originalImage.replace(/\/(mq)?default\.jpg$/, "/$N.jpg"); | |
} | |
if (item.mouseover) { | |
mouseover(); | |
} else { | |
mouseout(); | |
} | |
ytcenter.utils.addEventListener(item.wrapper, "mouseover", mouseover, false); | |
ytcenter.utils.addEventListener(item.wrapper, "mouseout", mouseout, false); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
function appendQuality(item, stream, errorMessage) { | |
var tableQuality = { | |
"error": errorMessage, | |
"auto": errorMessage, | |
"ondemand": "OnDemand", | |
"tiny": "144p", | |
"small": "240p", | |
"medium": "360p", | |
"large": "480p", | |
"hd720": "720p", | |
"hd1080": "1080p", | |
"hd1440": "1440p", | |
"highres": "1080p+" | |
}, | |
tableBackground = { | |
"error": "#b00", | |
"auto": "#b00", | |
"ondemand": "#aaa", | |
"tiny": "#7e587e", | |
"small": "#aaa", | |
"medium": "#0aa", | |
"large": "#00f", | |
"hd720": "#0a0", | |
"hd1080": "#f00", | |
"hd1440": "#000", | |
"highres": "#000" | |
}, | |
tableColor = { | |
"error": "#fff", | |
"auto": "#fff", | |
"ondemand": "#fff", | |
"tiny": "#fff", | |
"small": "#fff", | |
"medium": "#fff", | |
"large": "#fff", | |
"hd720": "#fff", | |
"hd1080": "#fff", | |
"hd1440": "#fff", | |
"highres": "#fff" | |
}, | |
text, background, color, wrapper = document.createElement("span"); | |
if (stream === null) { | |
text = tableQuality["error"]; | |
background = tableBackground["error"]; | |
color = tableColor["error"]; | |
} else if (stream === "error") { | |
text = tableQuality[stream]; | |
background = tableBackground[stream]; | |
color = tableColor[stream]; | |
} else if (stream && stream.quality === "ondemand") { | |
text = tableQuality[stream.quality]; | |
background = tableBackground[stream.quality]; | |
color = tableColor[stream.quality]; | |
} else if (stream && stream.quality && stream.dimension) { | |
text = stream.dimension.split("x")[1] + "p"; | |
background = tableBackground[stream.quality]; | |
color = tableColor[stream.quality]; | |
} else if (stream && stream.size) { | |
var quality = ytcenter.player.convertDimensionToQuality(stream.size); | |
text = stream.size.split("x")[1] + "p"; | |
background = tableBackground[quality]; | |
color = tableColor[quality]; | |
} | |
if (ytcenter.settings.videoThumbnailQualityFPS && stream && stream !== "error") { | |
var fps = stream.fps || "30"; | |
text += "@" + fps; | |
} | |
wrapper.className = (ytcenter.settings.videoThumbnailQualityVisible === "show_hover" ? " ytcenter-video-thumb-show-hover" : "") | |
+ (ytcenter.settings.videoThumbnailQualityVisible === "hide_hover" ? " ytcenter-video-thumb-hide-hover" : "") | |
+ " ytcenter-thumbnail-quality"; | |
wrapper.textContent = text; | |
item.content.className += " ytcenter-thumbnail-quality-pos-" + ytcenter.settings.videoThumbnailQualityPosition; | |
wrapper.style.background = background; | |
wrapper.style.color = color; | |
item.content.appendChild(wrapper); | |
} | |
function updateWatchedClass(item) { | |
var watched = ytcenter.utils.hasClass(item.content, "watched"), | |
am, li, s; | |
if (item.itemWrapper && watched) { | |
ytcenter.utils.addClass(item.itemWrapper, "ytcenter-video-watched-wrapper"); // For hiding the item | |
} else if (item.itemWrapper) { | |
ytcenter.utils.removeClass(item.itemWrapper, "ytcenter-video-watched-wrapper"); // For hiding the item | |
} | |
if (loc.pathname === "/feed/subscriptions" && !item.actionMenu) { | |
item.actionMenu = item.wrapper.parentNode.parentNode.parentNode.parentNode.parentNode.nextElementSibling; | |
if (item.actionMenu) { | |
am = item.actionMenu.getElementsByTagName("ul")[0]; | |
li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
s = document.createElement("span"); | |
s.className = "dismiss-menu-choice yt-uix-button-menu-item"; | |
s.setAttribute("onclick", ";return false;"); | |
if (ytcenter.videoHistory.isVideoWatched(item.id)) { | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_REMOVE"); | |
} else { | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_ADD"); | |
} | |
ytcenter.utils.addEventListener(li, "click", function(){ | |
if (ytcenter.videoHistory.isVideoWatched(item.id)) { | |
ytcenter.videoHistory.removeVideo(item.id); | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_ADD"); | |
} else { | |
ytcenter.videoHistory.addVideo(item.id); | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_REMOVE"); | |
} | |
updateWatchedMessage(item); | |
}, false); | |
li.appendChild(s); | |
am.insertBefore(li, am.children[0]); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
if (ytcenter.videoHistory.isVideoWatched(item.id)) { | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_REMOVE"); | |
} else { | |
s.textContent = ytcenter.language.getLocale("VIDEOWATCHED_ADD"); | |
} | |
}); | |
} | |
} | |
} | |
function updateWatchedMessage(item) { | |
var ivw = ytcenter.videoHistory.isVideoWatched(item.id), | |
watchedElement; | |
if (ivw) { | |
watchedElement = document.createElement("div"); | |
if (item.content.getElementsByClassName("watched-message").length === 0 | |
&& item.content.getElementsByClassName("watched-badge").length === 0) { | |
//watchedElement.className = "watched-message"; | |
watchedElement.className = "watched-badge"; | |
watchedElement.textContent = ytcenter.language.getLocale("SETTINGS_WATCHED"); | |
ytcenter.language.addLocaleElement(watchedElement, "SETTINGS_WATCHED", "@textContent"); | |
item.content.insertBefore(watchedElement, item.content.children[1]); | |
} | |
ytcenter.utils.addClass(item.content, "watched"); | |
} else { | |
ytcenter.utils.removeClass(item.content, "watched"); | |
if (item.itemWrapper) ytcenter.utils.removeClass(item.itemWrapper, "ytcenter-video-watched-wrapper"); | |
} | |
} | |
function getChannelBubble(item) { | |
var elm = null; | |
if (item.itemWrapper) { | |
elm = item.itemWrapper.getElementsByTagName("a"); | |
if (elm && elm.length > 0) { | |
elm = elm[0]; | |
} else { | |
elm = null; | |
} | |
} | |
return elm; | |
} | |
function getChannelName(wrapper) { | |
var elm = null; | |
if (wrapper) { | |
elm = wrapper.getElementsByTagName("img"); | |
if (elm && elm.length > 0) { | |
elm = elm[0]; | |
} | |
} | |
if (elm) { | |
elm = elm.getAttribute("alt"); | |
} | |
return elm; | |
} | |
function convertChannelBubble(elm) { | |
if (elm) { | |
elm.textContent = getChannelName(elm); | |
elm.className = elm.className.replace("feed-author-bubble", ""); | |
} | |
return elm; | |
} | |
function isInSubscription(item) { | |
var feed = document.getElementById("feed"), | |
children = feed.getElementsByClassName("video-thumb"), | |
i; | |
for (i = 0; i < children.length; i++) { | |
if (children[i] === item.videoThumb) { | |
return true; | |
} | |
} | |
return false; | |
} | |
function processItemHeavyLoad(item) { | |
if (!ytcenter.settings.videoThumbnailQualityBar && !ytcenter.settings.videoThumbnailAnimationEnabled) return; | |
if (ytcenter.settings.videoThumbnailQualityDownloadAt === "scroll_into_view") { | |
ytcenter.domEvents.addEvent(item.wrapper, "enterview", function(){ | |
loadVideoConfig(item, function(stream, storyboard, errorMessage){ | |
if (ytcenter.settings.videoThumbnailQualityBar) | |
appendQuality(item, stream, errorMessage); | |
if (ytcenter.settings.videoThumbnailAnimationEnabled) | |
appendAnimatedThumbnail(item, storyboard, errorMessage); | |
}); | |
}, true); | |
} else if (ytcenter.settings.videoThumbnailQualityDownloadAt === "hover_thumbnail") { | |
ytcenter.utils.addEventListener(item.wrapper, "mouseover", (function(){ | |
var added = false; | |
return function(){ | |
if (added) return; | |
added = true; | |
loadVideoConfig(item, function(stream, storyboard, errorMessage){ | |
if (ytcenter.settings.videoThumbnailQualityBar) | |
appendQuality(item, stream, errorMessage); | |
if (ytcenter.settings.videoThumbnailAnimationEnabled) | |
appendAnimatedThumbnail(item, storyboard, errorMessage); | |
}); | |
}; | |
})(), false); | |
} else { | |
loadVideoConfig(item, function(stream, storyboard, errorMessage){ | |
if (ytcenter.settings.videoThumbnailQualityBar) | |
appendQuality(item, stream, errorMessage); | |
if (ytcenter.settings.videoThumbnailAnimationEnabled) { | |
ytcenter.utils.addEventListener(item.wrapper, "mouseover", (function(){ | |
var added = false; | |
return function(){ | |
if (added) return; | |
added = true; | |
appendAnimatedThumbnail(item, storyboard, errorMessage); | |
}; | |
})(), false); | |
} | |
}); | |
} | |
} | |
function processItems(items) { | |
if (!items || items.length === 0) return; | |
if (!ytcenter.settings.videoThumbnailRatingsCount && !ytcenter.settings.videoThumbnailRatingsBar) return; | |
var options = [ "hover_thumbnail", "scroll_into_view", "page_start" ]; | |
var optionIndex = -1; | |
if (ytcenter.settings.videoThumbnailRatingsBar) { | |
optionIndex = Math.max(ytcenter.utils.indexOf_(options, ytcenter.settings.videoThumbnailRatingsBarDownloadAt), optionIndex); | |
} | |
if (ytcenter.settings.videoThumbnailRatingsCount) { | |
optionIndex = Math.max(ytcenter.utils.indexOf_(options, ytcenter.settings.videoThumbnailRatingsCountDownloadAt), optionIndex); | |
} | |
if (optionIndex === -1) return; | |
var option = options[optionIndex]; | |
var countEnabled = ytcenter.settings.videoThumbnailRatingsCount; | |
var barEnabled = ytcenter.settings.videoThumbnailRatingsBar; | |
if (option === "page_start") { | |
loadRatings(items, function(items){ | |
for (var i = 0; i < items.length; i++) { | |
if (countEnabled) { | |
appendRatingCount(items[i], items[i].likes, items[i].dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(items[i], items[i].likes, items[i].dislikes); | |
} | |
} | |
}); | |
} else if (option === "scroll_into_view") { | |
ytcenter.domEvents.addEvent(items.slice(), "enterview", function(items){ | |
loadRatings(items, function(items){ | |
for (var i = 0; i < items.length; i++) { | |
if (countEnabled) { | |
appendRatingCount(items[i], items[i].likes, items[i].dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(items[i], items[i].likes, items[i].dislikes); | |
} | |
} | |
}); | |
}, true); | |
} else if (option === "hover_thumbnail") { | |
for (var i = 0; i < items.length; i++) { | |
ytcenter.utils.addEventListener(items[i].wrapper, "mouseover", (function(item){ | |
var fn = function(){ | |
ytcenter.utils.removeEventListener(item.wrapper, "mouseover", fn, false); | |
loadVideoData(item, function(likes, dislikes){ | |
if (countEnabled) { | |
appendRatingCount(item, likes, dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(item, likes, dislikes); | |
} | |
}); | |
}; | |
return fn; | |
})(items[i]), false); | |
} | |
} | |
} | |
function processItem(item) { | |
if (!ytcenter.settings.videoThumbnailRatingsCount && !ytcenter.settings.videoThumbnailRatingsBar) return; | |
var options = [ "hover_thumbnail", "scroll_into_view", "page_start" ]; | |
var optionIndex = -1; | |
if (ytcenter.settings.videoThumbnailRatingsBar) { | |
optionIndex = Math.max(ytcenter.utils.indexOf_(options, ytcenter.settings.videoThumbnailRatingsBarDownloadAt), optionIndex); | |
} | |
if (ytcenter.settings.videoThumbnailRatingsCount) { | |
optionIndex = Math.max(ytcenter.utils.indexOf_(options, ytcenter.settings.videoThumbnailRatingsCountDownloadAt), optionIndex); | |
} | |
if (optionIndex === -1) return; | |
var option = options[optionIndex]; | |
var countEnabled = ytcenter.settings.videoThumbnailRatingsCount; | |
var barEnabled = ytcenter.settings.videoThumbnailRatingsBar; | |
if (option === "page_start") { | |
loadVideoData(item, function(likes, dislikes){ | |
if (countEnabled) { | |
appendRatingCount(item, likes, dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(item, likes, dislikes); | |
} | |
}); | |
} else if (option === "scroll_into_view") { | |
ytcenter.domEvents.addEvent(item.wrapper, "enterview", function(){ | |
loadVideoData(item, function(likes, dislikes){ | |
if (countEnabled) { | |
appendRatingCount(item, likes, dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(item, likes, dislikes); | |
} | |
}); | |
}, true); | |
} else if (option === "hover_thumbnail") { | |
ytcenter.utils.addEventListener(item.wrapper, "mouseover", (function(){ | |
var added = false; | |
return function(){ | |
if (added) return; | |
added = true; | |
loadVideoData(item, function(likes, dislikes){ | |
if (countEnabled) { | |
appendRatingCount(item, likes, dislikes); | |
} | |
if (barEnabled) { | |
appendRatingBar(item, likes, dislikes); | |
} | |
}); | |
}; | |
})(), false); | |
} else { | |
con.error("Unknown option for video thumbnail", option); | |
} | |
} | |
function compareDifference(newData, oldData) { | |
function inArray(arr, item) { | |
for (var i = 0; i < arr.length; i++) { | |
if (arr[i].wrapper === item.wrapper) { | |
return true; | |
} | |
} | |
return false; | |
} | |
var arr = []; | |
for (var i = 0, len = newData.length; i < len; i++) { | |
if (!inArray(oldData, newData[i])) { | |
arr.push(newData[i]); | |
} | |
} | |
return arr; | |
} | |
function updateItemInCache(data) { | |
var index = getDataCacheIndex(data); | |
if (data.stream && !ytcenter.settings.videoThumbnailData[index].stream) { | |
ytcenter.settings.videoThumbnailData[index].stream = data.stream; | |
} | |
if (data.storyboard && !ytcenter.settings.videoThumbnailData[index].storyboard) { | |
ytcenter.settings.videoThumbnailData[index].storyboard = data.storyboard; | |
} | |
if (data.likes && data.dislikes && !ytcenter.settings.videoThumbnailData[index].likes && !ytcenter.settings.videoThumbnailData[index].dislikes) { | |
ytcenter.settings.videoThumbnailData[index].likes = data.likes; | |
ytcenter.settings.videoThumbnailData[index].dislikes = data.dislikes; | |
} | |
ytcenter.saveSettings(); | |
} | |
function updateReuse(data) { | |
var index = getDataCacheIndex(data); | |
if (index === -1) return; | |
ytcenter.settings.videoThumbnailData[index].reused++; | |
if (ytcenter.settings.videoThumbnailData[index].reused > 5) | |
ytcenter.settings.videoThumbnailData[index].reused = 5; | |
ytcenter.saveSettings(); | |
} | |
function getDataCacheById(id) { | |
var i; | |
for (i = 0; i < ytcenter.settings.videoThumbnailData.length; i++) { | |
if (id === ytcenter.settings.videoThumbnailData[i].id) return ytcenter.settings.videoThumbnailData[i]; | |
} | |
return null; | |
} | |
function getDataCacheIndex(data) { | |
var i; | |
for (i = 0; i < ytcenter.settings.videoThumbnailData.length; i++) { | |
if (data.id === ytcenter.settings.videoThumbnailData[i].id) return i; | |
} | |
return -1; | |
} | |
function isInCache(data) { | |
return getDataCacheIndex(data) !== -1; | |
} | |
function addNewDataToCache(data) { | |
if (isInCache(data)) return; | |
var nData = {}; | |
while (ytcenter.settings.videoThumbnailData.length >= ytcenter.settings.videoThumbnailCacheSize) removeOldestFromCache(); | |
nData.id = data.id; | |
nData.reused = 0; | |
nData.date = ytcenter.utils.now(); | |
if (data.stream) nData.stream = data.stream; | |
if (data.storyboard) nData.storyboard = data.storyboard; | |
if (data.likes) nData.likes = data.likes; | |
if (data.dislikes) nData.dislikes = data.dislikes; | |
ytcenter.settings.videoThumbnailData.push(nData); | |
ytcenter.saveSettings(); | |
} | |
function calculateCacheLife(data) { | |
return 1000*60*10 + (1000*60*5)*(data.reused ? data.reused : 0); | |
} | |
function removeOldestFromCache() { | |
if (ytcenter.settings.videoThumbnailData.length === 0) return; | |
var i, now = ytcenter.utils.now(), life, lifeRemaining, oldest = ytcenter.settings.videoThumbnailData[0], j = 0; | |
for (i = 1; i < ytcenter.settings.videoThumbnailData.length; i++) { | |
life = calculateCacheLife(ytcenter.settings.videoThumbnailData[i]); | |
lifeRemaining = (ytcenter.settings.videoThumbnailData[i].date + life) - now; | |
if (lifeRemaining < (oldest.date + calculateCacheLife(oldest)) - now) { | |
oldest = ytcenter.settings.videoThumbnailData[i]; | |
j = i; | |
} | |
} | |
ytcenter.settings.videoThumbnailData.splice(j, 1); | |
} | |
function cacheChecker() { | |
if (ytcenter.settings.videoThumbnailData.length === 0) return; | |
var i, now = ytcenter.utils.now(), life, nData = []; | |
for (i = 0; i < ytcenter.settings.videoThumbnailData.length; i++) { | |
life = calculateCacheLife(ytcenter.settings.videoThumbnailData[i]); | |
if (now < ytcenter.settings.videoThumbnailData[i].date + life) { | |
if (ytcenter.settings.videoThumbnailData[i].reused < 5) ytcenter.settings.videoThumbnailData[i].reused++; | |
nData.push(ytcenter.settings.videoThumbnailData[i]); | |
} | |
} | |
ytcenter.settings.videoThumbnailData = nData; | |
ytcenter.saveSettings(); | |
} | |
var exports = {}, videoThumbs = [], observer = null, observer2 = null; | |
exports.update = function(){ | |
ytcenter.gridview.update(); | |
ytcenter.videoHistory.loadWatchedVideosFromYouTubePage(); | |
ytcenter.channelPlaylistLinks.update(); | |
var vt = compareDifference(getVideoThumbs(), videoThumbs), i; | |
processItems(vt); | |
for (i = 0; i < vt.length; i++) { | |
ytcenter.utils.addEventListener(vt[i].wrapper, "mouseover", (function(item){ | |
return function(){ item.mouseover = true; }; | |
})(vt[i]), false); | |
ytcenter.utils.addEventListener(vt[i].wrapper, "mouseout", (function(item){ | |
return function(){ item.mouseover = false; }; | |
})(vt[i]), false); | |
videoThumbs.push(vt[i]); | |
updateReuse(vt[i]); | |
// TODO make it load with scrolling. | |
/*if (vt[i].thumbnailImage && vt[i].thumbnailImage.hasAttribute("data-thumb")) { | |
vt[i].thumbnailImage.src = vt[i].thumbnailImage.getAttribute("data-thumb"); | |
}*/ | |
processItemHeavyLoad(vt[i]); | |
if (loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) { | |
updateWatchedClass(vt[i]); | |
} | |
if (((loc.pathname.indexOf("/user/") === 0 && loc.pathname.indexOf("/videos") !== -1) || loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) && ytcenter.settings.watchedVideosIndicator) { | |
updateWatchedMessage(vt[i]); | |
} | |
} | |
}; | |
exports.setupObserver = function(){ | |
exports.dispose(); // We don't want multiple observers | |
if (document.getElementById("content")) { | |
observer = ytcenter.mutation.observe(document.getElementById("content"), { childList: true, subtree: true }, function(){ | |
exports.update(); | |
}); | |
} | |
}; | |
exports.dispose = function(){ | |
if (observer) { | |
observer.disconnect(); | |
observer = null; | |
} | |
if (observer2) { | |
observer2.disconnect(); | |
observer2 = null; | |
} | |
}; | |
ytcenter.unload(exports.dispose); | |
exports.setup = function(){ | |
con.log("[Thumbnail] Setup has begun..."); | |
ytcenter.gridview.update(); | |
try { | |
var i; | |
cacheChecker(); | |
ytcenter.videoHistory.loadWatchedVideosFromYouTubePage(); | |
videoThumbs = getVideoThumbs(); | |
processItems(videoThumbs); | |
for (i = 0; i < videoThumbs.length; i++) { | |
ytcenter.utils.addEventListener(videoThumbs[i].wrapper, "mouseover", (function(item){ | |
return function(){ item.mouseover = true; }; | |
})(videoThumbs[i]), false); | |
ytcenter.utils.addEventListener(videoThumbs[i].wrapper, "mouseout", (function(item){ | |
return function(){ item.mouseover = false; }; | |
})(videoThumbs[i]), false); | |
updateReuse(videoThumbs[i]); | |
processItemHeavyLoad(videoThumbs[i]); | |
if (loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) { | |
updateWatchedClass(videoThumbs[i]); | |
} | |
if (((loc.pathname.indexOf("/user/") === 0 && loc.pathname.indexOf("/videos") !== -1) || loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) && ytcenter.settings.watchedVideosIndicator) { | |
updateWatchedMessage(videoThumbs[i]); | |
} | |
} | |
exports.setupObserver(); | |
} catch (e) { | |
con.error(e); | |
} | |
}; | |
var processedVideoIds = []; | |
return exports; | |
})(); | |
ytcenter.getDebug = function(stringify){ | |
if (typeof stringify !== "boolean") stringify = true; | |
var debugText = "{}", dbg = {}, a; | |
var api = ytcenter.player.getAPI(); | |
try { | |
dbg.htmlelements = {}; | |
if (document.body) | |
dbg.htmlelements.body = { "className": document.body.className }; | |
dbg.injected = injected; | |
dbg.identifier = identifier; | |
dbg.devbuild = devbuild; // variable is true if this a developer build | |
dbg.devnumber = devnumber; // developer build number. Only really needed for the developer build. | |
dbg.feather = ytcenter.feather; | |
dbg.cookies = {}; | |
dbg.cookies["VISITOR_INFO1_LIVE"] = ytcenter.utils.getCookie("VISITOR_INFO1_LIVE"); | |
dbg.location = { | |
hash: loc.hash, | |
host: loc.host, | |
hostname: loc.hostname, | |
href: loc.href, | |
origin: loc.origin, | |
pathname: loc.pathname, | |
port: loc.port, | |
protocol: loc.protocol, | |
search: loc.search | |
}; | |
dbg.navigator = { | |
userAgent: uw.navigator.userAgent, | |
vendor: uw.navigator.vendor, | |
vendorSub: uw.navigator.vendorSub, | |
platform: uw.navigator.platform | |
}; | |
dbg.settings = {}; | |
for (a in ytcenter.settings) { | |
if (ytcenter.settings.hasOwnProperty(a)) { | |
if (ytcenter.settings.debug_settings_playersize && a === "resize-playersizes") continue; | |
if (ytcenter.settings.debug_settings_buttonPlacement && (a === "buttonPlacement" || a === "buttonPlacementWatch7")) continue; | |
if (ytcenter.settings.debug_settings_videoThumbnailData && a === "videoThumbnailData") continue; | |
if (ytcenter.settings.debug_settings_commentCountryData && a === "commentCountryData") continue; | |
if (ytcenter.settings.debug_settings_watchedVideos && a === "watchedVideos") continue; | |
if (ytcenter.settings.debug_settings_notwatchedVideos && a === "notwatchedVideos") continue; | |
dbg.settings[a] = ytcenter.settings[a]; | |
} | |
} | |
dbg.settings = ytcenter.settings; | |
dbg.ytcenter = {}; | |
dbg.ytcenter.video = ytcenter.video; | |
dbg.ytcenter.signatureDecipher = ytcenter.utils._signatureDecipher; | |
dbg.ytcenter._signatureDecipher = ytcenter.utils.__signatureDecipher; | |
dbg.ytcenter.player = {}; | |
dbg.ytcenter.player.flashvars = ""; | |
try { | |
dbg.ytcenter.player.flashvars = document.getElementById("movie_player").getAttribute("flashvars"); | |
} catch (e) { | |
dbg.ytcenter.player.flashvars = e; | |
} | |
dbg.ytcenter.player.config = ytcenter.player.config; | |
try { | |
dbg.ytcenter.player.apiinterface = api.getApiInterface(); | |
} catch (e) { | |
dbg.ytcenter.player.apiinterface = {}; | |
} | |
if (typeof dbg.ytcenter.player.reference !== "undefined") { | |
dbg.ytcenter.player.reference = true; | |
} else { | |
dbg.ytcenter.player.reference = false; | |
} | |
try { | |
dbg.player_test = {}; | |
for (var key in api) { | |
if (key.indexOf("is") !== 0 && key.indexOf("get") !== 0) { | |
dbg.player_test[key] = "IGNORED"; | |
continue; | |
} | |
if (api.hasOwnProperty(key)) { | |
try { | |
dbg.player_test[key] = api[key](); | |
} catch (e) { | |
dbg.player_test[key] = e; | |
} | |
} | |
} | |
} catch (e) { | |
dbg.player_test_error = "ERROR"; | |
} | |
dbg.console = _console; | |
if (stringify) { | |
debugText = JSON.stringify(dbg); | |
} else { | |
debugText = dbg; | |
} | |
} catch (e) { | |
con.error(e); | |
con.log("[Debug Text]", dbg); | |
debugText = e.message; | |
} | |
return debugText; | |
}; | |
ytcenter.alert = function(type, message, closeable){ | |
var exports = {}, | |
types = { | |
"error": "yt-alert-error", | |
"warning": "yt-alert-warning", | |
"info": "yt-alert-info" | |
}, | |
wrapper = document.createElement("div"), | |
icon = document.createElement("div"), | |
iconImg = document.createElement("img"), | |
content = document.createElement("div"), | |
contentVerticalTrick = document.createElement("span"), | |
contentMessage = document.createElement("div"); | |
closeable = typeof closeable === "boolean" ? closeable : true; | |
wrapper.className = "yt-alert yt-alert-default " + types[type]; | |
icon.className = "yt-alert-icon"; | |
iconImg.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
iconImg.className = "icon master-sprite"; | |
icon.appendChild(iconImg); | |
wrapper.appendChild(icon); | |
if (closeable) { | |
var buttons = document.createElement("div"), | |
closeButton = document.createElement("button"), | |
closeButtonText = document.createElement("span"); | |
buttons.className = "yt-alert-buttons"; | |
closeButton.setAttribute("type", "button"); | |
closeButton.setAttribute("role", "button"); | |
closeButton.setAttribute("onclick", ";return false;"); | |
closeButton.className = "close yt-uix-close yt-uix-button yt-uix-button-close"; | |
ytcenter.utils.addEventListener(closeButton, "click", function(){ | |
exports.setVisibility(false); | |
}); | |
closeButtonText.className = "yt-uix-button-content"; | |
closeButtonText.textContent = "Close "; | |
closeButton.appendChild(closeButtonText); | |
buttons.appendChild(closeButton); | |
wrapper.appendChild(buttons); | |
} | |
content.className = "yt-alert-content"; | |
contentVerticalTrick.className = "yt-alert-vertical-trick"; | |
contentMessage.className = "yt-alert-message"; | |
if (typeof message === "string") { | |
contentMessage.textContent = message; | |
} else { | |
contentMessage.appendChild(message); | |
} | |
content.appendChild(contentVerticalTrick); | |
content.appendChild(contentMessage); | |
wrapper.appendChild(content); | |
exports.setVisibility = function(visible){ | |
if (visible) { | |
if (wrapper.parentNode) wrapper.parentNode.removeChild(wrapper); | |
document.getElementById("alerts").appendChild(wrapper); | |
} else { | |
if (wrapper.parentNode) wrapper.parentNode.removeChild(wrapper); | |
} | |
}; | |
return exports; | |
}; | |
ytcenter.message = (function(){ | |
var exports = {}; | |
exports.listen = function(win, origin, token, callback){ | |
ytcenter.utils.addEventListener(win || uw, "message", function(e){ | |
if (origin && e.origin !== origin) return; | |
if (!e || !e.data) return; // Checking if data is present | |
if (typeof e.data !== "string") return; // Checking if the object is a string. | |
if (!e.data.indexOf || e.data.indexOf(token) !== 0) return; // Checking if the token is present at the start of the string | |
var data = JSON.parse(e.data.substring(token.length)); | |
//con.log("[Message:" + loc.href + "] Listen@" + token, data); | |
callback(data); | |
}, false); | |
}; | |
exports.broadcast = function(win, origin, token, data){ | |
win.postMessage(token + JSON.stringify(data), origin); | |
}; | |
return exports; | |
})(); | |
ytcenter.domEvents = (function(){ | |
function onViewUpdate(e) { | |
if (e && e.detail === "ytcenter") return; | |
if (uw.self !== uw.top && !offset && !windowDim) | |
return; | |
onEnterViewUpdate(); | |
onExitViewUpdate(); | |
var i, elms = document.getElementsByTagName("iframe"), scrollOffset = null, elmOffset = null, data; | |
for (i = 0; i < elms.length; i++) { | |
if (elms[i] && elms[i].src && (elms[i].src.indexOf("http://apis.google.com/") === 0 || elms[i].src.indexOf("https://apis.google.com/") === 0 || elms[i].src.indexOf("http://plus.googleapis.com") === 0 || elms[i].src.indexOf("https://plus.googleapis.com") === 0) && elms[i].src.indexOf("/widget/render/comments?") !== -1) { | |
scrollOffset = ytcenter.utils.getBoundingClientRect(elms[i]); | |
data = { scrollOffset: scrollOffset, windowDim: windowDim || {width: window.innerWidth || document.documentElement.clientWidth, height: window.innerHeight || document.documentElement.clientHeight } }; | |
ytcenter.message.broadcast( | |
elms[i].contentWindow, | |
elms[i].src, | |
"$_scroll", | |
data | |
); | |
} | |
} | |
} | |
function onEnterViewUpdate() { | |
if (!db["enterview"]) return; | |
var trash = [], i = 0, a; | |
while (i < db["enterview"].length) { | |
if (processEnterViewUpdate(db["enterview"][i])) { | |
if (db["enterview"][i].once) { | |
db["enterview"].splice(i, 1); | |
i -= 1; | |
} | |
} | |
i += 1; | |
} | |
} | |
function onExitViewUpdate() { | |
if (!db["exitview"]) return; | |
var trash = [], i = 0, a; | |
while (i < db["exitview"].length) { | |
if (processExitViewUpdate(db["exitview"][i])) { | |
if (db["exitview"][i].once) { | |
db["exitview"].splice(i, 1); | |
i -= 1; | |
} | |
} | |
i += 1; | |
} | |
} | |
function processEnterViewUpdate(item) { | |
if (item.element) { | |
var inView = ytcenter.utils.isElementPartlyInView(item.element, offset, windowDim); | |
if (!inView) { | |
item.inview = false; | |
return false; | |
} | |
if (!("inview" in item)) item.inview = false; | |
if (item.inview) return false; | |
item.inview = true; | |
item.callback.apply(item.element, []); | |
return true; | |
} else if (item.collection) { | |
var items = item.collection; | |
var inViewItems = []; | |
for (var i = 0, len = item.collection.length; i < len; i++) { | |
var inview = ytcenter.utils.isElementPartlyInView(items[i].wrapper, offset, windowDim); | |
if (inview) { | |
inViewItems.push(item.collection[i]); | |
item.collection.splice(i, 1); | |
i--; len--; | |
} | |
} | |
item.callback.call(null, inViewItems); | |
return (item.collection.length === 0); | |
} | |
} | |
function processExitViewUpdate(item) { | |
if (item.element) { | |
var inView = ytcenter.utils.isElementPartlyInView(item.element, offset, windowDim); | |
if (inView) { | |
item.inview = true; | |
return false; | |
} | |
if (!("inview" in item)) { | |
item.inview = inView; | |
return false; | |
} | |
if (item.inview && !inView) { | |
item.callback.apply(item.element, []); | |
} | |
item.inview = inView; | |
return true; | |
} else if (item.collection) { | |
return false; | |
} | |
} | |
var exports = {}, db = {}, _buffer = null, onViewUpdateBuffer = null, offset = null, windowDim = null; | |
exports.update = function(){ | |
onViewUpdate(); | |
}; | |
exports.addEvent = function(elm, event, callback, once){ | |
if (!elm) return; | |
if (!db[event]) db[event] = []; | |
if (ytcenter.utils.isArray(elm)) { | |
db[event].push({ | |
collection: elm, | |
callback: callback, | |
once: once || false | |
}); | |
} else { | |
db[event].push({ | |
element: elm, | |
inview: false, | |
callback: callback, | |
once: once || false | |
}); | |
} | |
}; | |
exports.ready = function(){ | |
if (uw.self === uw.top) return; | |
if ((loc.href.indexOf("apis.google.com/u/") !== -1 || loc.href.indexOf("plus.googleapis.com") !== -1) && loc.href.indexOf("/widget/render/comments?") !== -1) { | |
ytcenter.message.broadcast( | |
uw.parent, | |
document.referrer, | |
"$_ready", | |
{} | |
); | |
} | |
}; | |
exports.setup = function(){ | |
if (onViewUpdateBuffer) { | |
ytcenter.utils.removeEventListener(window, "scroll", onViewUpdateBuffer, false); | |
ytcenter.utils.removeEventListener(window, "resize", onViewUpdateBuffer, false); | |
ytcenter.events.removeEvent("ui-refresh", onViewUpdateBuffer); | |
} else { | |
if ((loc.href.indexOf("apis.google.com/u/") !== -1 || loc.href.indexOf("plus.googleapis.com") !== -1) && loc.href.indexOf("/widget/render/comments?") !== -1) { | |
ytcenter.message.listen(uw, null, "$_scroll", function(data){ | |
offset = data.scrollOffset; | |
windowDim = data.windowDim; | |
}); | |
} | |
if (ytcenter.getPage() === "watch") { | |
ytcenter.message.listen(uw, null, "$_ready", function(data){ | |
onViewUpdate(); | |
}); | |
} | |
} | |
onViewUpdateBuffer = ytcenter.utils.throttle(onViewUpdate, 500); | |
ytcenter.utils.addEventListener(window, "scroll", onViewUpdateBuffer, false); | |
ytcenter.utils.addEventListener(window, "resize", onViewUpdateBuffer, false); | |
ytcenter.events.addEvent("ui-refresh", onViewUpdateBuffer); | |
uw.setInterval(onViewUpdateBuffer, 7500); // Todo attach this to an event instead. | |
onViewUpdateBuffer(); | |
}; | |
return exports; | |
})(); | |
ytcenter.scrollEvent = (function(){ | |
function createHandler(group) { | |
return function(event){ | |
var data = handler(event), | |
i; | |
for (i = 0; i < group.listeners.length; i++) { | |
group.listeners[i].apply(group.element, data); | |
} | |
}; | |
} | |
function addEventListener(elm, listener) { | |
var group = getEventGroup(elm); | |
if (group === null) { | |
group = { | |
element: elm, | |
listeners: [], | |
handler: null | |
}; | |
groups.push(group); | |
} | |
group.listeners.push(listener); | |
if (group.listeners.length > 0 && group.handler === null) { | |
setupGroup(group); | |
} | |
} | |
function removeEventListener(elm, listener) { | |
var group = getEventGroup(elm), | |
i; | |
if (group !== null) { | |
for (i = 0; i < group.listeners.length; i++) { | |
if (group.listeners[i] === listener) { | |
group.listeners.splice(i, 1); | |
} | |
} | |
if (group.listeners.length === 0 && group.handler !== null) { | |
destroyGroup(group); | |
} | |
} | |
} | |
function getEventGroup(elm) { | |
var i; | |
for (i = 0; i < groups.length; i++) { | |
if (groups[i].element === elm) { | |
return groups[i]; | |
} | |
} | |
return null; | |
} | |
function setupGroup(group) { | |
var i; | |
if (group.handler === null) { | |
group.handler = createHandler(group); | |
for (i = 0; i < events.length; i++) { | |
ytcenter.utils.addEventListener(group.element, events[i], group.handler, false); | |
} | |
} | |
} | |
function destroyGroup(group) { | |
var i; | |
if (group.handler !== null) { | |
for (i = 0; i < events.length; i++) { | |
ytcenter.utils.removeEventListener(group.element, events[i], group.handler, false); | |
} | |
group.handler = null; | |
} | |
} | |
function setup() { | |
var i; | |
for (i = 0; i < groups.length; i++) { | |
setupGroup(groups[i]); | |
} | |
} | |
function destroy() { | |
var i; | |
for (i = 0; i < groups.length; i++) { | |
destroyGroup(groups[i]); | |
} | |
} | |
function unload() { | |
destroy(); | |
groups = []; | |
} | |
function handler(event) { | |
var orgEvent = event || window.event; | |
var args = Array.prototype.splice.call(arguments, 1); | |
var delta = 0; | |
var deltaX = 0; | |
var deltaY = 0; | |
var absDelta = 0; | |
var absDeltaXY = 0; | |
var fn = null; | |
// Old school scrollwheel delta | |
if (orgEvent.wheelDelta) { | |
delta = orgEvent.wheelDelta; | |
} | |
if (orgEvent.detail) { | |
delta = orgEvent.detail * -1; | |
} | |
// New school wheel delta (wheel event) | |
if (orgEvent.deltaY) { | |
deltaY = orgEvent.deltaY * -1; | |
delta = deltaY; | |
} | |
if (orgEvent.deltaX) { | |
deltaX = orgEvent.deltaX; | |
delta = deltaX * -1; | |
} | |
// Webkit | |
if (orgEvent.wheelDeltaY !== undefined) { | |
deltaY = orgEvent.wheelDeltaY; | |
} | |
if (orgEvent.wheelDeltaX !== undefined) { | |
deltaX = orgEvent.wheelDeltaX * -1; | |
} | |
// Look for lowest delta to normalize the delta values | |
absDelta = Math.abs(delta); | |
if (!lowestDelta || absDelta < lowestDelta) { | |
lowestDelta = absDelta; | |
} | |
absDeltaXY = Math.max(Math.abs(deltaY), Math.abs(deltaX)); | |
if (!lowestDeltaXY || absDeltaXY < lowestDeltaXY) { | |
lowestDeltaXY = absDeltaXY; | |
} | |
fn = delta > 0 ? "floor" : "ceil"; | |
delta = Math[fn](delta / lowestDelta); | |
deltaX = Math[fn](deltaX / lowestDeltaXY); | |
deltaY = Math[fn](deltaY / lowestDeltaXY); | |
return [event, delta, deltaX, deltaY]; | |
} | |
var events = 'onwheel' in document || document.documentMode >= 9 ? ["wheel"] : ["mousewheel", "DomMouseScroll", "MozMousePixelScroll"], | |
lowestDelta = null, | |
lowestDeltaXY = null, | |
groups = []; | |
return { | |
addEventListener: addEventListener, | |
removeEventListener: removeEventListener, | |
destroy: destroy, | |
setup: setup, | |
unload: unload | |
}; | |
})(); | |
ytcenter.events = (function(){ | |
function SubscriptionEvent(type, fn) { | |
this.type = type; | |
this.fn = fn; | |
this.flag = SubscriptionEvent.FLAG_DEFAULT; | |
this.dispatch = ytcenter.utils.bind(this, this.dispatch); | |
this.addEvent = ytcenter.utils.bind(this, this.addEvent); | |
this.removeEvent = ytcenter.utils.bind(this, this.removeEvent); | |
this.setFlag = ytcenter.utils.bind(this, this.setFlag); | |
} | |
SubscriptionEvent.FLAG_DEFAULT = "default"; | |
SubscriptionEvent.FLAG_DOM_UNLOAD = "unload"; | |
SubscriptionEvent.prototype.dispatch = function dispatch(scope) { | |
var args = Array.prototype.splice.call(arguments, 1, arguments.length); | |
this.fn.apply(scope, args); | |
return this; | |
} | |
SubscriptionEvent.prototype.addEvent = function addEvent() { | |
db.push(this); | |
return this; | |
} | |
SubscriptionEvent.prototype.removeEvent = function removeEvent() { | |
_removeEvent(this.type, this.fn); | |
return this; | |
} | |
SubscriptionEvent.prototype.setFlag = function setFlag(flag) { | |
this.flag = flag; | |
return this; | |
} | |
function _addEvent(type, fn) { | |
return (new SubscriptionEvent(type, fn)).addEvent(); | |
} | |
function _removeEvent(type, fn) { | |
for (var i = 0, len = db.length; i < len; i++) { | |
if (db[i].type === type && db[i].fn === fn) { | |
db.splice(i, 1); | |
return true; | |
} | |
} | |
return false; | |
} | |
function _performEvent(type) { | |
var staticArguments = Array.prototype.splice.call(arguments, 1, arguments.length); | |
for (var i = 0, len = db.length; i < len; i++) { | |
if (db[i].type === type) { | |
try { db[i].dispatch.apply(db[i], [this].concat(staticArguments)); } | |
catch (e) { con.error(e); } | |
} | |
} | |
} | |
function onDOMUnload() { | |
for (var i = 0, len = db.length; i < len; i++) { | |
if (db[i].flag === SubscriptionEvent.FLAG_DOM_UNLOAD) { | |
db.splice(i, 1); | |
i--; len--; | |
} | |
} | |
} | |
var db = []; | |
ytcenter.spf.addEventListener("request", onDOMUnload); | |
//window.addEventListener("unload", onDOMUnload, false); | |
var exports = {}; | |
exports.addEvent = _addEvent; | |
exports.removeEvent = _removeEvent; | |
exports.performEvent = _performEvent; | |
return exports; | |
})(); | |
(function(){ | |
function onBeforeUnload(e) { | |
e = e || window.event; | |
ytcenter.saveSettings(false); | |
} | |
window.addEventListener("beforeunload", onBeforeUnload, false); | |
})(); | |
ytcenter._dialogVisible = null | |
ytcenter.dialog = function(titleLabel, content, actions, alignment){ | |
var exports = {}, ___parent_dialog = null, bgOverlay, root, base, fg, fgContent, footer, eventListeners = {}, actionButtons = {}, _visible = false; | |
var buttons = []; | |
alignment = alignment || "center"; | |
bgOverlay = ytcenter.dialogOverlay(); | |
root = document.createElement("div"); | |
root.className = "ytcenter-dialog"; | |
base = document.createElement("div"); | |
base.className = "ytcenter-dialog-base"; | |
fg = document.createElement("div"); | |
fg.className = "ytcenter-dialog-fg"; | |
fgContent = document.createElement("div"); | |
fgContent.className = "ytcenter-dialog-fg-content ytcenter-dialog-show-content"; | |
fg.appendChild(fgContent); | |
if (alignment === "center") { | |
var align = document.createElement("span"); | |
align.className = "ytcenter-dialog-align"; | |
base.appendChild(align); | |
} else { | |
fg.style.margin = "13px 0"; | |
} | |
base.appendChild(fg); | |
root.appendChild(base); | |
if (typeof titleLabel === "string" && titleLabel !== "") { | |
var header = document.createElement("div"); | |
header.className = "ytcenter-dialog-header"; | |
var title = document.createElement("h2"); | |
title.className = "ytcenter-dialog-title"; | |
title.textContent = ytcenter.language.getLocale(titleLabel); | |
ytcenter.language.addLocaleElement(title, titleLabel, "@textContent"); | |
header.appendChild(title); | |
fgContent.appendChild(header); | |
} else { | |
var header = document.createElement("div"); | |
header.style.margin = "0 -20px 20px"; | |
fgContent.appendChild(header); | |
} | |
if (typeof content !== "undefined") { | |
var cnt = document.createElement("div"); | |
cnt.className = "ytcenter-dialog-content"; | |
cnt.appendChild(content); | |
fgContent.appendChild(cnt); | |
} | |
footer = document.createElement("div"); | |
footer.className = "ytcenter-dialog-footer"; | |
fgContent.appendChild(footer); | |
if (typeof actions !== "undefined") { | |
/* Array | |
* Object | |
* label: "", | |
* primary: false, # Should be the primary button. | |
* callback: Function | |
*/ | |
for (var i = 0; i < actions.length; i++) { | |
var btn = document.createElement("button"); | |
buttons.push(btn); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.className = "yt-uix-button " + (actions[i].primary ? "yt-uix-button-primary" : "yt-uix-button-default"); | |
if (typeof actions[i].callback === "function") { | |
ytcenter.utils.addEventListener(btn, "click", actions[i].callback, false); | |
} | |
var btnContent = document.createElement("span"); | |
btnContent.className = "yt-uix-button-content"; | |
btnContent.textContent = ytcenter.language.getLocale(actions[i].label); | |
ytcenter.language.addLocaleElement(btnContent, actions[i].label, "@textContent"); | |
btn.appendChild(btnContent); | |
footer.appendChild(btn); | |
if (actions[i].name) actionButtons[actions[i].name] = btn; | |
} | |
} else { // Default | |
var closeBtn = document.createElement("button"); | |
buttons.push(closeBtn); | |
closeBtn.setAttribute("type", "button"); | |
closeBtn.setAttribute("role", "button"); | |
closeBtn.setAttribute("onclick", ";return false;"); | |
closeBtn.className = "yt-uix-button yt-uix-button-default"; | |
ytcenter.utils.addEventListener(closeBtn, "click", function(){ | |
exports.setVisibility(false); | |
}, false); | |
var closeContent = document.createElement("span"); | |
closeContent.className = "yt-uix-button-content"; | |
closeContent.textContent = ytcenter.language.getLocale("DIALOG_CLOSE"); | |
ytcenter.language.addLocaleElement(closeContent, "DIALOG_CLOSE", "@textContent"); | |
closeBtn.appendChild(closeContent); | |
footer.appendChild(closeBtn); | |
actionButtons['close'] = btn; | |
} | |
exports.getActionButton = function(name){ | |
return actionButtons[name]; | |
}; | |
exports.addEventListener = function(eventName, func){ | |
if (!eventListeners.hasOwnProperty(eventName)) eventListeners[eventName] = []; | |
eventListeners[eventName].push(func); | |
return eventListeners[eventName].length - 1; | |
}; | |
exports.removeEventListener = function(eventName, index){ | |
if (!eventListeners.hasOwnProperty(eventName)) return; | |
if (index < 0 && index >= eventListeners[eventName].length) return; | |
eventListeners[eventName].splice(index, 1); | |
}; | |
exports.setWidth = function(width){ | |
fg.style.width = width; | |
}; | |
exports.getRoot = function(){ | |
return root; | |
}; | |
exports.getBase = function(){ | |
return base; | |
}; | |
exports.getContent = function(){ | |
return cnt; | |
}; | |
exports.getFooter = function(){ | |
return footer; | |
}; | |
exports.getHeader = function(){ | |
return header; | |
}; | |
exports.setPureVisibility = function(visible){ | |
if (visible) { | |
if (!root.parentNode) document.body.appendChild(root); | |
else { | |
root.parentNode.removeChild(root); | |
document.body.appendChild(root); | |
} | |
if (!bgOverlay.parentNode) document.body.appendChild(bgOverlay); | |
else { | |
bgOverlay.parentNode.removeChild(bgOverlay); | |
document.body.appendChild(bgOverlay); | |
} | |
if (document.getElementById("player-api-legacy") || document.getElementById("player-api")) (document.getElementById("player-api-legacy") || document.getElementById("player-api")).style.visibility = "hidden"; | |
} else { | |
if (root.parentNode) root.parentNode.removeChild(root); | |
if (bgOverlay.parentNode) bgOverlay.parentNode.removeChild(bgOverlay); | |
if ((document.getElementById("player-api-legacy") || document.getElementById("player-api")) && !___parent_dialog) (document.getElementById("player-api-legacy") || document.getElementById("player-api")).style.visibility = ""; | |
} | |
}; | |
exports.setFocus = function(focus){ | |
if (!base) { | |
con.error("[Dialog.setFocus] base element was not found!"); | |
return; | |
} | |
if (focus) { | |
base.style.zIndex = ""; | |
} else { | |
base.style.zIndex = "1998"; | |
} | |
}; | |
exports.setVisibility = function(visible){ | |
if (_visible === visible) return; | |
_visible = visible; | |
if (eventListeners["visibility"]) { | |
for (var i = 0; i < eventListeners["visibility"].length; i++) { | |
eventListeners["visibility"][i](visible); | |
} | |
} | |
if (visible) { | |
if (document.body) ytcenter.utils.addClass(document.body, "ytcenter-dialog-active"); | |
___parent_dialog = ytcenter._dialogVisible; | |
if (___parent_dialog) { | |
___parent_dialog.setFocus(false); | |
} | |
exports.setPureVisibility(true); | |
ytcenter._dialogVisible = exports; | |
} else { | |
exports.setPureVisibility(false); | |
if (___parent_dialog) { | |
___parent_dialog.setFocus(true); | |
ytcenter._dialogVisible = ___parent_dialog; | |
} else { | |
ytcenter._dialogVisible = null; | |
if (document.body) ytcenter.utils.removeClass(document.body, "ytcenter-dialog-active"); | |
} | |
} | |
}; | |
exports.setButtonsEnabled = function(enabled){ | |
for (var i = 0, len = buttons.length; i < len; i++) { | |
buttons[i].disabled = !enabled; | |
} | |
}; | |
exports.isVisible = function(){ | |
return _visible; | |
}; | |
return exports; | |
}; | |
ytcenter.dialogOverlay = function(){ | |
var bg = document.createElement("div"); | |
bg.id = "ytcenter-dialog-bg"; | |
bg.className = "ytcenter-dialog-bg"; | |
bg.style.height = Math.max(document.body.scrollHeight, document.body.offsetHeight, document.documentElement.clientHeight, document.documentElement.scrollHeight, document.documentElement.offsetHeight) + "px"; | |
bg.style.position = "absolute"; | |
return bg; | |
}; | |
ytcenter.confirmBox = function(titleLabel, messageLabel, onConfirm, confirmLabel){ // Only being used for the resizeitemlist | |
confirmLabel = confirmLabel || "EMBED_RESIZEITEMLIST_CONFIRM_DISCARD"; | |
var msgElm = document.createElement("h3"); | |
msgElm.style.fontWeight = "normal"; | |
msgElm.textContent = ytcenter.language.getLocale(messageLabel); | |
ytcenter.language.addLocaleElement(msgElm, messageLabel, "@textContent"); | |
var dialog = ytcenter.dialog(titleLabel, msgElm, [ | |
{ | |
label: "CONFIRM_CANCEL", | |
primary: false, | |
callback: function(){ | |
try { | |
onConfirm(false); | |
dialog.setVisibility(false); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
}, { | |
label: confirmLabel, | |
primary: true, | |
callback: function(){ | |
try { | |
onConfirm(true); | |
dialog.setVisibility(false); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
} | |
]); | |
dialog.setVisibility(true); | |
}; | |
ytcenter.welcome = (function(){ | |
function update() { | |
return ytcenter.utils.replaceText(ytcenter.language.getLocale("WELCOME_CONTENT"), | |
{ | |
"{lb}": function(){ | |
return document.createElement("br"); | |
}, | |
"{sectionbreak}": function(){ | |
var c = document.createElement("div"); | |
c.style.marginTop = "40px"; | |
return c; | |
}, | |
"{img1}": img1, | |
"{wiki-url}": wikilink, | |
"{donate}": donatelink | |
} | |
); | |
} | |
var a = {}, dialog, b = document.createElement("div"), | |
img1 = document.createElement("div"), img1src = document.createElement("img"), wikilink = document.createElement("a"), donatelink = document.createElement("a"); | |
img1.className = "ytcenter-image-welcome-settings-repeater"; | |
img1src.className = "ytcenter-image-welcome-settings clearfix"; | |
img1src.style.cssFloat = "right"; | |
img1src.style.backgroundPosition = "right"; | |
img1src.style.width = "100%"; | |
img1src.src = "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"; | |
img1.appendChild(img1src); | |
wikilink.href = "https://github.com/YePpHa/YouTubeCenter/wiki"; | |
wikilink.setAttribute("target", "_blank"); | |
donatelink.href = "https://github.com/YePpHa/YouTubeCenter/wiki/Donate"; | |
donatelink.setAttribute("target", "_blank"); | |
a.createDialog = function(){ | |
if (dialog) return; | |
donatelink.textContent = ytcenter.language.getLocale("WELCOME_CONTENT_DONATE"); | |
ytcenter.language.addLocaleElement(donatelink, "WELCOME_CONTENT_DONATE", "@textContent"); | |
wikilink.textContent = ytcenter.language.getLocale("WELCOME_CONTENT_WIKI"); | |
ytcenter.language.addLocaleElement(wikilink, "WELCOME_CONTENT_WIKI", "@textContent"); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
b.innerHTML = ""; | |
b.appendChild(update()); | |
}); | |
b.appendChild(update()); | |
dialog = ytcenter.dialog("WELCOME_TITLE", b, [ | |
{ | |
label: "DIALOG_CLOSE", | |
primary: false, | |
callback: function(){ | |
try { | |
a.setLaunchStatus(true); | |
a.setVisibility(false); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
}, { | |
label: "WELCOME_CONFIRM_SETTINGS", | |
primary: true, | |
callback: function(){ | |
try { | |
a.setLaunchStatus(true); | |
a.setVisibility(false); | |
if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); | |
ytcenter.settingsPanelDialog.setVisibility(true); | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
} | |
]); | |
dialog.setWidth("530px"); | |
}; | |
a.setLaunchStatus = function(launch){ | |
ytcenter.settings['welcome_launched'] = launch; | |
ytcenter.saveSettings(); | |
}; | |
a.hasBeenLaunched = function(){ | |
return ytcenter.settings['welcome_launched'] ? true : false; | |
}; | |
a.setVisibility = function(visible){ | |
a.createDialog(); | |
if (visible) { | |
ytcenter.utils.addClass(document.body, "player-disable"); | |
} else { | |
ytcenter.utils.removeClass(document.body, "player-disable"); | |
} | |
dialog.setVisibility(visible); | |
}; | |
return a; | |
})(); | |
ytcenter.dragdrop = function(list){ | |
function mousemove(e) { | |
if (!dragging) return; | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
var target = e.target; | |
if (e && e.type.indexOf("touched") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { | |
e = e.changedTouches[0]; | |
} | |
var t = ytcenter.utils.toParent(target, "ytcenter-dragdrop-item"); | |
if (t === draggingElement || t === document.body || typeof t === "undefined") return; | |
var offset = ytcenter.utils.getOffset(target, t); | |
var top = (typeof e.offsetY === "undefined" ? e.layerY : e.offsetY) + offset.top; | |
if (top > t.clientHeight/2) { | |
if (t.nextSibling === draggingElement) return; | |
ytcenter.utils.insertAfter(draggingElement, t); | |
} else { | |
if (t.previousSibling === draggingElement) return; | |
t.parentNode.insertBefore(draggingElement, t); | |
} | |
ytcenter.utils.each(listeners.onDragging, function(i, callback){ | |
callback(getItemIndex(draggingElement) /* Current Index */, draggingIndex, draggingElement); | |
}); | |
return false; | |
} | |
function mousedownListener(e) { | |
if (!ytcenter.utils.hasClass(e.target, "ytcenter-dragdrop-handle")) return; | |
if (!ytcenter.utils.hasChild(list, e.target)) return; | |
draggingElement = ytcenter.utils.toParent(e.target, "ytcenter-dragdrop-item"); | |
if (typeof draggingElement === "undefined") return; | |
dragging = true; | |
ytcenter.utils.addClass(draggingElement, "ytcenter-dragdrop-dragging"); | |
ytcenter.utils.addClass(list, "ytcenter-dragdrop-indragging"); | |
ytcenter.utils.removeClass(list, "ytcenter-dragdrop-notdragging"); | |
draggingIndex = getItemIndex(draggingElement); | |
ytcenter.utils.each(listeners.onDrag, function(i, callback){ | |
callback(draggingIndex, draggingElement); | |
}); | |
throttleFunc = ytcenter.utils.throttle(mousemove, 50); | |
ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false); | |
ytcenter.utils.addEventListener(document, "touchmove", throttleFunc, false); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function mouseupListener(e) { | |
if (!dragging) return; | |
dragging = false; | |
ytcenter.utils.removeClass(draggingElement, "ytcenter-dragdrop-dragging"); | |
ytcenter.utils.removeClass(list, "ytcenter-dragdrop-indragging"); | |
ytcenter.utils.addClass(list, "ytcenter-dragdrop-notdragging"); | |
ytcenter.utils.each(listeners.onDrop, function(i, callback){ | |
callback(getItemIndex(draggingElement) /* Drop Index */, draggingIndex, draggingElement); | |
}); | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "mousemove", throttleFunc); | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "touchmove", throttleFunc); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function getItemIndex(item) { | |
for (var i = 0; i < list.children.length; i++) { | |
if (list.children[i] === item) return i; | |
} | |
return -1; | |
} | |
var dragging = false; | |
var draggingElement; | |
var draggingIndex; | |
var offset; | |
var listeners = { | |
onDrag: [], | |
onDragging: [], | |
onDrop: [] | |
}; | |
var throttleFunc = null; | |
ytcenter.utils.addClass(list, "ytcenter-dragdrop-notdragging"); | |
ytcenter.utils.addEventListener(list, "mousedown", mousedownListener); | |
ytcenter.utils.addEventListener(document, "mouseup", mouseupListener); | |
ytcenter.utils.addEventListener(list, "touchstart", mousedownListener); | |
ytcenter.utils.addEventListener(document, "touchend", mouseupListener); | |
return { | |
addEventListener: function(event, callback){ | |
if (typeof listeners[event] === "undefined") listeners[event] = []; | |
listeners[event].push(callback); | |
} | |
}; | |
}; | |
ytcenter.style = {}; | |
ytcenter.style.update = function(){ | |
var containerWidth = 985, | |
guideWidth = 175, | |
guideOffset = 10, | |
contentWidth = 640, | |
sidebarOffset = 0; | |
var pageWidth = containerWidth + 2*(guideWidth + guideOffset), | |
sidebarWidth = containerWidth - contentWidth - sidebarOffset; | |
// @media and screen (max-width: ...){...} | |
}; | |
ytcenter.listeners = (function(){ | |
var exports = {}; | |
exports.addEvent = function(elm, event, callback, useCapture){ | |
if (elm.addEventListener) { | |
elm.addEventListener(event, callback, useCapture || false); | |
} else if (elm.attachEvent) { | |
elm.attachEvent("on" + event, callback); | |
} | |
}; | |
return exports; | |
})(); | |
ytcenter.gui = {}; | |
ytcenter.gui.icons = {}; | |
ytcenter.gui.icons.cog = ""; | |
ytcenter.gui.createMiddleAlignHack = function(content){ | |
var e = document.createElement("div"), | |
a = document.createElement("span"); | |
a.className = "yt-dialog-align"; | |
content.style.verticalAlign = "middle"; | |
content.style.display = "inline-block"; | |
e.appendChild(a); | |
e.appendChild(content); | |
return e; | |
}; | |
ytcenter.gui.createYouTubeButtonIcon = function(src){ | |
var wrapper = document.createElement("span"); | |
wrapper.className = "yt-uix-button-icon-wrapper"; | |
var img = document.createElement("img"); | |
img.src = src; | |
img.alt = ""; | |
img.style.marginLeft = "3px"; | |
wrapper.appendChild(img); | |
return wrapper; | |
}; | |
ytcenter.gui.createYouTubeButtonArrow = function(){ | |
var img = document.createElement("img"); | |
img.className = "yt-uix-button-arrow"; | |
img.src = "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"; | |
img.alt = ""; | |
return img; | |
}; | |
ytcenter.gui.createYouTubeTextInput = function(){ | |
var elm = document.createElement("input"); | |
elm.setAttribute("type", "text"); | |
elm.className = "yt-uix-form-input-text"; | |
return elm; | |
}; | |
ytcenter.gui.createYouTubeCheckBox = function(selected){ | |
if (typeof selected === "undefined") selected = false; | |
var cw = document.createElement("span"); | |
cw.className = "yt-uix-form-input-checkbox-container" + (selected ? " checked" : ""); | |
cw.style.height = "auto"; | |
var checkbox = document.createElement("input"); | |
checkbox.setAttribute("type", "checkbox"); | |
checkbox.setAttribute("value", "true"); | |
checkbox.className = "yt-uix-form-input-checkbox"; | |
if (selected) checkbox.checked = true; | |
var elm = document.createElement("span"); | |
elm.className = "yt-uix-form-input-checkbox-element"; | |
cw.appendChild(checkbox); | |
cw.appendChild(elm); | |
return cw; | |
}; | |
ytcenter.gui.createYouTubeButtonText = function(text){ | |
var wrapper = document.createElement("span"); | |
wrapper.className = "yt-uix-button-content"; | |
wrapper.textContent = text; | |
return wrapper; | |
}; | |
ytcenter.gui.createYouTubeButtonTextLabel = function(label){ | |
var wrapper = document.createElement("span"); | |
wrapper.className = "yt-uix-button-content"; | |
wrapper.textContent = ytcenter.language.getLocale(label); | |
ytcenter.language.addLocaleElement(wrapper, label, "@textContent"); | |
return wrapper; | |
}; | |
ytcenter.gui.createYouTubeButton = function(title, content, styles){ | |
var btn = document.createElement("button"); | |
if (typeof title === "string" && title !== "") { | |
btn.setAttribute("title", ytcenter.language.getLocale(title)); | |
ytcenter.language.addLocaleElement(btn, title, "title"); | |
} | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.className = "yt-uix-tooltip-reverse yt-uix-button yt-uix-button-text yt-uix-tooltip"; | |
if (typeof styles !== "undefined") { | |
for (var key in styles) { | |
if (styles.hasOwnProperty(key)) { | |
btn.style[key] = styles[key]; | |
} | |
} | |
} | |
for (var i = 0; i < content.length; i++) { | |
btn.appendChild(content[i]); | |
} | |
return btn; | |
}; | |
ytcenter.gui.createYouTubeDefaultButton = function(title, content, styles){ | |
var btn = document.createElement("button"); | |
if (title !== "") { | |
btn.setAttribute("title", ytcenter.language.getLocale(title)); | |
ytcenter.language.addLocaleElement(btn, title, "title"); | |
} | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.className = "yt-uix-button yt-uix-button-default yt-uix-tooltip"; | |
if (typeof styles !== "undefined") { | |
for (var key in styles) { | |
if (styles.hasOwnProperty(key)) { | |
btn.style[key] = styles[key]; | |
} | |
} | |
} | |
for (var i = 0; i < content.length; i++) { | |
btn.appendChild(content[i]); | |
} | |
return btn; | |
}; | |
ytcenter.gui.createYouTubePrimaryButton = function(title, content, styles){ | |
var btn = document.createElement("button"); | |
if (title !== "") { | |
btn.setAttribute("title", ytcenter.language.getLocale(title)); | |
ytcenter.language.addLocaleElement(btn, title, "title"); | |
} | |
btn.setAttribute("role", "button"); | |
btn.setAttribute("type", "button"); | |
btn.setAttribute("onclick", ";return false;"); | |
btn.setAttribute("class", "yt-uix-tooltip-reverse yt-uix-button yt-uix-button-primary yt-uix-tooltip"); | |
if (typeof styles !== "undefined") { | |
for (var key in styles) { | |
if (styles.hasOwnProperty(key)) { | |
btn.style[key] = styles[key]; | |
} | |
} | |
} | |
for (var i = 0; i < content.length; i++) { | |
btn.appendChild(content[i]); | |
} | |
return btn; | |
}; | |
ytcenter.gui.createYouTubeButtonGroup = function(buttons){ | |
// <span style="margin: 0px 4px 0px 0px;" class="yt-uix-button-group yt-uix-tooltip-reverse"> start end | |
var wrapper = document.createElement("span"); | |
wrapper.className = "yt-uix-button-group"; | |
for (var i = 0; i < buttons.length; i++) { | |
if (i == 0) { | |
ytcenter.utils.addClass(buttons[i], "start"); | |
} else { | |
ytcenter.utils.removeClass(buttons[i], "start"); | |
} | |
if (i === buttons.length-1) { | |
ytcenter.utils.addClass(buttons[i], "end"); | |
} else { | |
ytcenter.utils.removeClass(buttons[i], "end"); | |
} | |
wrapper.appendChild(buttons[i]); | |
} | |
return wrapper; | |
}; | |
ytcenter.gui.createYouTubeGuideHelpBoxAfter = function(){ | |
var after = document.createElement("div"); | |
after.className = "after"; | |
return after; | |
}; | |
ytcenter.gui.createMask = function(zIndex){ | |
zIndex = zIndex || "4"; | |
var iframe = document.createElement("iframe"); | |
iframe.setAttribute("frameborder", "0"); | |
iframe.setAttribute("src", ""); | |
iframe.style.position = "absolute"; | |
iframe.style.top = "0px"; | |
iframe.style.left = "0px"; | |
iframe.style.width = "100%"; | |
iframe.style.height = "100%"; | |
iframe.style.overflow = "hidden"; | |
iframe.style.zIndex = zIndex; | |
return iframe; | |
}; | |
ytcenter.listeners = (function(){ | |
var exports = {}; | |
exports.addEvent = function(elm, event, callback, useCapture){ | |
if (elm.addEventListener) { | |
elm.addEventListener(event, callback, useCapture || false); | |
} else if (elm.attachEvent) { | |
elm.attachEvent("on" + event, callback); | |
} | |
}; | |
return exports; | |
})(); | |
ytcenter.modules = {}; | |
ytcenter.modules.layoutExperiments = function(option){ | |
function loadExperiments() { | |
loadedOnce = true; | |
setButtonStatus(1); | |
ytcenter.utils.xhr({ | |
method: "GET", | |
url: "https://raw.github.com/YePpHa/YouTubeCenter/master/data/ytexperiments.json", | |
ignoreCache: true, | |
headers: { | |
"Content-Type": "text/plain" | |
}, | |
onload: function(response){ | |
try { | |
var data = JSON.parse(response.responseText); | |
ytcenter.settings[option.defaultSetting] = data; | |
ytcenter.saveSettings(); | |
setButtonStatus(2); | |
setStatus("Updated"); | |
update(); | |
} catch (e) { | |
con.error(e); | |
setButtonStatus(3); | |
setStatus("error"); | |
} | |
}, | |
onerror: function(){ | |
setButtonStatus(3); | |
setStatus("error"); | |
} | |
}); | |
} | |
function setButtonStatus(status) { | |
if (setButtonStatusTimer) uw.clearTimeout(setButtonStatusTimer); | |
if (status === 0) { | |
updateButton.setText("MODULES_YTEXPERIMENTS_UPDATELIST"); | |
updateButton.setEnabled(true); | |
} else if (status === 1) { | |
updateButton.setText("MODULES_YTEXPERIMENTS_UPDATINGLIST"); | |
updateButton.setEnabled(false); | |
} else if (status === 2) { | |
updateButton.setText("MODULES_YTEXPERIMENTS_UPDATEDLIST"); | |
updateButton.setEnabled(true); | |
setButtonStatusTimer = uw.setTimeout(function(){ | |
setButtonStatus(0); | |
}, 2500); | |
} else if (status === 3) { | |
updateButton.setText("MODULES_YTEXPERIMENTS_UPDATELISTERROR"); | |
updateButton.setEnabled(true); | |
} | |
} | |
function createText(data, replace) { | |
function getText() { | |
if (data.locale) { | |
return ytcenter.language.getLocale(data.locale) || data.raw; | |
} else if (data.raw_locales) { | |
if (data.raw_locales[language]) { | |
return data.raw_locales[language]; | |
} else { | |
return data.raw_locales["en-US"] || data.raw; | |
} | |
} else if (data.raw) { | |
return data.raw; | |
} | |
} | |
var node = document.createTextNode((replace ? ytcenter.utils.replaceTextToText(getText(), replace) : getText())); | |
unloadEventList.push(ytcenter.events.addEvent("language-refresh", function(){ | |
node.textContent = (replace ? ytcenter.utils.replaceTextToText(getText(), replace) : getText()); | |
})); | |
return node; | |
} | |
function createListItem(data) { | |
var wrapper = document.createElement("li"); | |
wrapper.className = "clearfix"; | |
if (data.preview) { | |
var previewWrapper = document.createElement("div"), | |
redirectElm = document.createElement("a"), | |
img = document.createElement("img"), | |
src = ""; | |
if (ytcenter.utils.isArray(data.preview)) { | |
if (data.preview.length > 0) { | |
var rand = Math.floor(Math.random()*data.preview.length); | |
src = data.preview[rand]; | |
} | |
} else { | |
src = data.preview; | |
} | |
redirectElm.href = src; | |
redirectElm.setAttribute("target", "_blank"); | |
img.src = src; | |
previewWrapper.className = "layoutExperimentPreview"; | |
redirectElm.appendChild(img); | |
previewWrapper.appendChild(redirectElm); | |
wrapper.appendChild(previewWrapper); | |
} | |
var content = document.createElement("div"); | |
content.className = "layoutExperimentContent"; | |
if (data.description) { | |
var descriptionWrapper = document.createElement("div"), | |
descriptionTitle = document.createElement("h3"), | |
descriptionContent = document.createElement("span"); | |
descriptionWrapper.className = "layoutExperimentDescription"; | |
descriptionTitle.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_DESCRIPTION"); // Raw: Description | |
unloadEventList.push(ytcenter.events.addEvent("language-refresh", function(){ | |
descriptionTitle.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_DESCRIPTION"); | |
})); | |
descriptionContent.appendChild(createText(data.description)); | |
descriptionWrapper.appendChild(descriptionTitle); | |
descriptionWrapper.appendChild(descriptionContent); | |
content.appendChild(descriptionWrapper); | |
} | |
if (data.features) { | |
var featuresWrapper = document.createElement("div"), | |
featuresTitle = document.createElement("h3"), | |
featuresContent = document.createElement("ul"); | |
featuresWrapper.className = "layoutExperimentFeatures"; | |
featuresContent.className = "layoutExperimentFeaturesList"; | |
featuresTitle.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_FEATURES"); // Raw: Description | |
unloadEventList.push(ytcenter.events.addEvent("language-refresh", function(){ | |
featuresTitle.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_FEATURES"); | |
})); | |
featuresWrapper.appendChild(featuresTitle); | |
var i; | |
for (i = 0; i < data.features.length; i++) { | |
var item = document.createElement("li"); | |
item.appendChild(createText(data.features[i])); | |
featuresContent.appendChild(item); | |
} | |
featuresWrapper.appendChild(featuresContent); | |
content.appendChild(featuresWrapper); | |
} | |
if (data.screenshots) { | |
var screenshotsWrapper = document.createElement("div"); | |
screenshotsWrapper.className = "layoutExperimentScreenshots"; | |
var i; | |
for (i = 0; i < data.screenshots.length; i++) { | |
var screenshot = document.createElement("a"); | |
screenshot.href = data.screenshots[i]; | |
screenshot.setAttribute("target", "_blank"); | |
screenshot.appendChild(createText({ locale: "MODULES_YTEXPERIMENTS_SCREENSHOTS" }, { "{number}": i + 1 })); | |
screenshotsWrapper.appendChild(screenshot); | |
} | |
content.appendChild(screenshotsWrapper); | |
} | |
if (data.date) { | |
// data = { expires: some data, created/started: some date } | |
} | |
if (data.codes) { | |
var codesWrapper = document.createElement("div"), | |
codesButton = ytcenter.modules.button({ | |
args: { | |
text: "MODULES_YTEXPERIMENTS_CODES_SELECT", | |
listeners: [ | |
{ | |
event: "click", | |
callback: function(){ | |
applyCookieCode(data.codes[0]); | |
} | |
} | |
] | |
} | |
}); | |
codesWrapper.className = "layoutExperimentCodes"; | |
codesWrapper.appendChild(codesButton.element); | |
if (content.children.length > 0) { | |
content.lastChild.className += " layoutExperimentPad"; | |
} | |
content.appendChild(codesWrapper); | |
} | |
wrapper.appendChild(content); | |
return wrapper; | |
} | |
function update() { | |
var i; | |
unloadEvents(); // Unloading events | |
list.innerHTML = ""; // Clearing the list | |
if (ytcenter.settings[option.defaultSetting].length === 0) { | |
var listItem = document.createElement("li"); | |
listItem.className = "empty"; | |
listItem.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_EMPTY"); // Raw: Description | |
unloadEventList.push(ytcenter.events.addEvent("language-refresh", function(){ | |
listItem.textContent = ytcenter.language.getLocale("MODULES_YTEXPERIMENTS_EMPTY"); | |
})); | |
list.appendChild(listItem); | |
} else { | |
for (i = 0; i < ytcenter.settings[option.defaultSetting].length; i++) { | |
list.appendChild(createListItem(ytcenter.settings[option.defaultSetting][i])); | |
} | |
} | |
} | |
function unloadEvents() { | |
for (var i = 0, len = unloadEventList.length; i < len; i++) { | |
unloadEventList[i].removeEvent(); | |
} | |
unloadEventList = []; | |
} | |
function setStatus(text) { } | |
function applyCookieCode(code) { | |
ytcenter.utils.setCookie("VISITOR_INFO1_LIVE", code, ".youtube.com", "/", 3600*60*24*30); | |
loc.reload(); | |
} | |
function init() { | |
var headerWrapper = document.createElement("div"), | |
setCodeWrapper = document.createElement("div"); | |
updateButton.element.className += " layoutExperimentsHeaderUpdateListButton"; | |
setCodeWrapper.className = "layoutExperimentsHeaderSetCodeButton"; | |
setButtonInput.style.width = "85px"; | |
setButtonInput.style.height = "15px"; | |
setButtonInput.style.verticalAlign = "middle"; | |
setButtonInput.value = ytcenter.utils.getCookie("VISITOR_INFO1_LIVE") || ""; | |
setCodeWrapper.appendChild(setButton.element); | |
setCodeWrapper.appendChild(setButtonInput); | |
headerWrapper.appendChild(setCodeWrapper); | |
headerWrapper.appendChild(updateButton.element); | |
elm.className = "ytcenter-modules-layoutExperiments"; | |
headerWrapper.className = "layoutExperimentsHeader clearfix"; | |
list.className = "layoutExperimentList"; | |
elm.appendChild(headerWrapper); | |
elm.appendChild(list); | |
} | |
var elm = document.createElement("div"), | |
list = document.createElement("ul"), | |
updateButton = ytcenter.modules.button({ | |
args: { | |
text: "MODULES_YTEXPERIMENTS_UPDATELIST", | |
listeners: [ | |
{ | |
event: "click", | |
callback: function(){ | |
loadExperiments(); | |
} | |
} | |
] | |
} | |
}), | |
setButton = ytcenter.modules.button({ | |
args: { | |
text: "MODULES_YTEXPERIMENTS_SETCODE", | |
listeners: [ | |
{ | |
event: "click", | |
callback: function(){ | |
applyCookieCode(setButtonInput.value); | |
} | |
} | |
] | |
} | |
}), | |
setButtonInput = ytcenter.gui.createYouTubeTextInput(), | |
unloadEventList = [], | |
setButtonStatusTimer = null, | |
loadedOnce = false; | |
init(); | |
update(); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){ update(); }, | |
loadExperiments: function(){ loadExperiments(); }, | |
hasLoadedOnce: function(){ return loadedOnce; } | |
}; | |
}; | |
ytcenter.modules.simpleElement = function(option){ | |
var exports = {}; | |
exports.element = option.args.element; | |
exports.bind = function(){}; | |
exports.update = function(){}; | |
return exports; | |
}; | |
ytcenter.modules.aboutText = function(option){ | |
var elm = document.createElement("div"), | |
content1 = document.createElement("div"); | |
content1.textContent = ytcenter.language.getLocale("SETTINGS_ABOUT_COPYRIGHTS"); | |
elm.appendChild(content1); | |
elm.appendChild(document.createElement("br")); | |
elm.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("SETTINGS_ABOUT_TEXT"), { | |
"{email}": function(){ | |
var a = document.createElement("a"); | |
a.href = "mailto:jepperm@gmail.com"; | |
a.textContent = "jepperm@gmail.com"; | |
return a; | |
}, | |
"{lb}": function(){ | |
return document.createElement("br"); | |
} | |
})); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
elm.innerHTML = ""; | |
content1 = document.createElement("div"); | |
content1.textContent = ytcenter.language.getLocale("SETTINGS_ABOUT_COPYRIGHTS"); | |
elm.appendChild(content1); | |
elm.appendChild(document.createElement("br")); | |
elm.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("SETTINGS_ABOUT_TEXT"), { | |
"{email}": function(){ | |
var a = document.createElement("a"); | |
a.href = "mailto:jepperm@gmail.com"; | |
a.textContent = "jepperm@gmail.com"; | |
return a; | |
}, | |
"{lb}": function(){ | |
return document.createElement("br"); | |
} | |
})); | |
}); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.bool = function(option){ | |
function update(checked) { | |
checkboxInput.checked = checked; | |
if (checked) { | |
ytcenter.utils.addClass(checkboxOuter, "checked"); | |
} else { | |
ytcenter.utils.removeClass(checkboxOuter, "checked"); | |
} | |
} | |
function bind(callback) { | |
boundCallback = callback; | |
} | |
var boundCallback = null, | |
frag = document.createDocumentFragment(), | |
checkboxOuter = document.createElement("span"), | |
checkboxInput = document.createElement("input"), | |
checkboxOverlay = document.createElement("span"), | |
checked = ytcenter.settings[option.defaultSetting]; | |
if (typeof checked !== "boolean") checked = false; // Just to make sure it's a boolean! | |
checkboxOuter.className = "yt-uix-form-input-checkbox-container" + (checked ? " checked" : ""); | |
checkboxInput.className = "yt-uix-form-input-checkbox"; | |
checkboxOverlay.className = "yt-uix-form-input-checkbox-element"; | |
checkboxInput.checked = checked; | |
checkboxInput.setAttribute("type", "checkbox"); | |
checkboxInput.setAttribute("value", checked); | |
checkboxOuter.appendChild(checkboxInput); | |
checkboxOuter.appendChild(checkboxOverlay); | |
ytcenter.utils.addEventListener(checkboxOuter, "click", function(){ | |
checked = !checked; | |
if (checked) { | |
ytcenter.utils.addClass(checkboxOuter, "checked"); | |
checkboxInput.checked = true; | |
} else { | |
ytcenter.utils.removeClass(checkboxOuter, "checked"); | |
checkboxInput.checked = false; | |
} | |
checkboxInput.setAttribute("value", checked); | |
if (boundCallback) boundCallback(checked); | |
if (option && option.args && option.args.listeners) { | |
for (var i = 0; i < option.args.listeners.length; i++) { | |
if (option.args.listeners[i].event === "click") option.args.listeners[i].callback.apply(this, arguments); | |
} | |
} | |
}, false); | |
frag.appendChild(checkboxOuter); | |
return { | |
element: frag, | |
bind: bind, | |
update: update | |
}; | |
}; | |
ytcenter.modules.button = function(option){ | |
var elm = document.createElement("button"), | |
languageListener = null, | |
localeText = null; | |
elm.setAttribute("type", "button"); | |
elm.setAttribute("role", "button"); | |
elm.setAttribute("onclick", ";return false;"); | |
elm.className = "yt-uix-button yt-uix-button-default"; | |
var c = document.createElement("span"); | |
c.className = "yt-uix-button-content"; | |
if (option && option.args && option.args.text) { | |
localeText = option.args.text; | |
c.textContent = ytcenter.language.getLocale(localeText); | |
languageListener = ytcenter.events.addEvent("language-refresh", function(){ | |
c.textContent = ytcenter.language.getLocale(localeText); | |
}); | |
} | |
if (option && option.args && option.args.listeners) { | |
for (var j = 0; j < option.args.listeners.length; j++) { | |
elm.addEventListener(option.args.listeners[j].event, option.args.listeners[j].callback, (option.args.listeners[j].bubble ? option.args.listeners[j].bubble : false)); | |
} | |
} | |
if (option && option.args && option.args.style) { | |
for (var key in option.args.style) { | |
if (option.args.style.hasOwnProperty(key)) { | |
elm.style[key] = option.args.style[key]; | |
} | |
} | |
} | |
elm.appendChild(c); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){}, | |
addEventListener: function(event, callback, bubble){ | |
elm.addEventListener(event, callback, bubble); | |
}, | |
removeEventListener: function(event, callback, bubble){ | |
elm.removeEventListener(event, callback, bubble); | |
}, | |
setText: function(text){ | |
localeText = text; | |
c.textContent = ytcenter.language.getLocale(localeText); | |
if (!languageListener) { | |
languageListener = ytcenter.events.addEvent("language-refresh", function(){ | |
c.textContent = ytcenter.language.getLocale(localeText); | |
}) | |
} | |
}, | |
setStyle: function(key, value){ | |
elm.style[key] = value; | |
}, | |
setEnabled: function(enabled){ | |
elm.disabled = !enabled; | |
} | |
}; | |
}; | |
ytcenter.modules.checkbox = function(selected){ | |
selected = selected || false; | |
var wrapper = document.createElement("span"); | |
wrapper.className = "ytcenter-embed"; | |
var cw = document.createElement("span"); | |
cw.className = "yt-uix-form-input-checkbox-container" + (selected ? " checked" : ""); | |
var checkbox = document.createElement("input"); | |
checkbox.setAttribute("type", "checkbox"); | |
checkbox.setAttribute("value", "true"); | |
checkbox.className = "yt-uix-form-input-checkbox"; | |
if (selected) checkbox.checked = true; | |
var elm = document.createElement("span"); | |
elm.className = "yt-uix-form-input-checkbox-element"; | |
cw.appendChild(checkbox); | |
cw.appendChild(elm); | |
wrapper.appendChild(cw); | |
return { | |
element: wrapper, // So the element can be appended to an element. | |
bind: function(callback){ | |
ytcenter.utils.addEventListener(checkbox, "change", function(){ | |
callback(ytcenter.utils.hasClass(cw, "checked")); | |
}, false); | |
}, | |
update: function(value){ | |
if (value === true) { | |
ytcenter.utils.addClass(cw, "checked"); | |
checkbox.checked = true; | |
} else { | |
ytcenter.utils.removeClass(cw, "checked"); | |
checkbox.checked = false; | |
} | |
}, | |
fixHeight: function(){ | |
cw.style.height = "auto"; | |
}, | |
isSelected: function(){ | |
return checkbox.checked; | |
} | |
}; | |
}; | |
ytcenter.modules.colorpicker = function(option){ | |
function update() { | |
wrapper.style.background = ytcenter.utils.colorToHex(red, green, blue); | |
currentColor.style.background = ytcenter.utils.colorToHex(red, green, blue); | |
redRange.update(red); | |
greenRange.update(green); | |
blueRange.update(blue); | |
htmlColor.update(ytcenter.utils.colorToHex(red, green, blue)); | |
} | |
function updateHueRange() { | |
if (Math.max(red, green, blue) !== Math.min(red, green, blue)) { | |
hsv = ytcenter.utils.getHSV(red, green, blue); | |
hueRange.update(hsv.hue); | |
} else { | |
var __hsv = ytcenter.utils.getHSV(red, green, blue); | |
if (hsv.value > hsv.saturation) { | |
hsv.saturation = __hsv.saturation; | |
} else if (hsv.value < hsv.saturation) { | |
hsv.value = __hsv.value; | |
} else { | |
hsv.saturation = __hsv.saturation; | |
hsv.value = __hsv.value; | |
} | |
hueRange.update(hsv.hue); | |
} | |
} | |
function updateColorField() { | |
if (Math.max(red, green, blue) !== Math.min(red, green, blue)) { | |
hsv = ytcenter.utils.getHSV(red, green, blue); | |
hueRangeField.update(hsv.hue, hsv.saturation, hsv.value); | |
} else { | |
var __hsv = ytcenter.utils.getHSV(red, green, blue); | |
if (hsv.value > hsv.saturation) { | |
hsv.saturation = __hsv.saturation; | |
} else if (hsv.value < hsv.saturation) { | |
hsv.value = __hsv.value; | |
} else { | |
hsv.saturation = __hsv.saturation; | |
hsv.value = __hsv.value; | |
} | |
hueRangeField.update(hsv.hue, hsv.saturation, hsv.value); | |
} | |
} | |
var red = 0, green = 0, blue = 0, sessionHex = "#000000", hsv = ytcenter.utils.getHSV(red, green, blue), _hue = hsv.hue, bCallback, | |
wrapper = document.createElement("span"), | |
redRange = ytcenter.modules.range({ | |
args: { | |
value: red, | |
min: 0, | |
max: 255 | |
} | |
}), greenRange = ytcenter.modules.range({ | |
args: { | |
value: green, | |
min: 0, | |
max: 255 | |
} | |
}), blueRange = ytcenter.modules.range({ | |
args: { | |
value: blue, | |
min: 0, | |
max: 255 | |
} | |
}), | |
rWrapper = document.createElement("div"), | |
rText = ytcenter.modules.label({label: "COLORPICKER_COLOR_RED"}), | |
gWrapper = document.createElement("div"), | |
gText = ytcenter.modules.label({label: "COLORPICKER_COLOR_GREEN"}), | |
bWrapper = document.createElement("div"), | |
bText = ytcenter.modules.label({label: "COLORPICKER_COLOR_BLUE"}), | |
hueWrapper = document.createElement("div"), | |
hueRangeField = ytcenter.modules.colorPickerField(), | |
rgb, hueRangeHandle = document.createElement("div"), | |
hueRangeHandleRight = document.createElement("div"), | |
hueRange = ytcenter.modules.range({ | |
args: { | |
value: hsv.hue, | |
min: 0, | |
max: 360, | |
method: "vertical", | |
handle: hueRangeHandle, | |
offset: 7 | |
} | |
}), d1, d2, d3, d4, d5, d6, | |
hWrapper = document.createElement("div"), | |
htmlColorLabel = ytcenter.utils.wrapModule(ytcenter.modules.label({label: "COLORPICKER_COLOR_HTMLCODE"})), | |
htmlColor = ytcenter.modules.textfield(), | |
currentColor = document.createElement("span"), | |
rgbWrapper = document.createElement("div"), | |
cpWrapper = document.createElement("div"), | |
dialog; | |
wrapper.className += " ytcenter-modules-colorpicker"; | |
redRange.bind(function(value){ | |
red = value; | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
}); | |
greenRange.bind(function(value){ | |
green = value; | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
}); | |
blueRange.bind(function(value){ | |
blue = value; | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
}); | |
rWrapper.appendChild(rText.element); | |
rWrapper.appendChild(redRange.element); | |
gWrapper.appendChild(gText.element); | |
gWrapper.appendChild(greenRange.element); | |
bWrapper.appendChild(bText.element); | |
bWrapper.appendChild(blueRange.element); | |
hueWrapper.className += " ytcenter-modules-colorpicker-huewrapper"; | |
hueRangeField.bind(function(saturation, value){ | |
hsv.saturation = saturation; | |
hsv.value = value; | |
rgb = ytcenter.utils.getRGB(hsv.hue, hsv.saturation, hsv.value); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
update(); | |
}); | |
hueRangeField.element.className += " ytcenter-modules-colorpickerfield-hue"; | |
hueRangeHandle.className += " ytcenter-modules-range-handle"; | |
hueRangeHandleRight.className += " ytcenter-modules-range-handle-right"; | |
hueRangeHandle.appendChild(hueRangeHandleRight); | |
hueRange.element.className += " ytcenter-modules-huerange ytcenter-modules-hue"; | |
d1 = document.createElement("div"); | |
d1.className = "ie-1"; | |
d2 = document.createElement("div"); | |
d2.className = "ie-2"; | |
d3 = document.createElement("div"); | |
d3.className = "ie-3"; | |
d4 = document.createElement("div"); | |
d4.className = "ie-4"; | |
d5 = document.createElement("div"); | |
d5.className = "ie-5"; | |
d6 = document.createElement("div"); | |
d6.className = "ie-6"; | |
hueRange.element.appendChild(d1); | |
hueRange.element.appendChild(d2); | |
hueRange.element.appendChild(d3); | |
hueRange.element.appendChild(d4); | |
hueRange.element.appendChild(d5); | |
hueRange.element.appendChild(d6); | |
hueRange.bind(function(value){ | |
hsv.hue = value; | |
rgb = ytcenter.utils.getRGB(hsv.hue, hsv.saturation, hsv.value); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
update(); | |
updateColorField(); | |
}); | |
hWrapper.className += " ytcenter-modules-hwrapper"; | |
htmlColorLabel.className += " ytcenter-modules-htmlcolorlabel"; | |
htmlColor.bind(function(value){ | |
rgb = ytcenter.utils.hexToColor(value); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
hsv = ytcenter.utils.getHSV(red, green, blue); | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
}); | |
htmlColor.element.className += " ytcenter-modules-htmlcolor"; | |
currentColor.className += " ytcenter-modules-currentcolor"; | |
currentColor.style.background = sessionHex; | |
htmlColor.element.appendChild(currentColor); | |
hWrapper.appendChild(htmlColorLabel); | |
hWrapper.appendChild(htmlColor.element); | |
rgbWrapper.className += " ytcenter-modules-rgbwrapper"; | |
rgbWrapper.appendChild(rWrapper); | |
rgbWrapper.appendChild(gWrapper); | |
rgbWrapper.appendChild(bWrapper); | |
rgbWrapper.appendChild(hWrapper); | |
if (option && option.args && option.args.presetColors && option.args.presetColors.length > 0) { | |
var presets = document.createElement("div"), | |
presetsLabel = ytcenter.utils.wrapModule(ytcenter.modules.label({label: "COLORPICKER_PRESETS"})), | |
i, color; | |
presets.className = "ytcenter-colorpicker-presets clearfix"; | |
presetsLabel.className = "ytcenter-colorpicker-presets-label"; | |
presets.appendChild(presetsLabel); | |
for (i = 0; i < option.args.presetColors.length; i++) { | |
color = document.createElement("div"); | |
color.className = "ytcenter-colorpicker-presets-color"; | |
color.style.background = option.args.presetColors[i]; | |
ytcenter.utils.addEventListener(color, "click", (function(bgcolor){ | |
return function(){ | |
rgb = ytcenter.utils.hexToColor(bgcolor); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
hsv = ytcenter.utils.getHSV(red, green, blue); | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
}; | |
})(option.args.presetColors[i]), false); | |
presets.appendChild(color); | |
} | |
rgbWrapper.appendChild(presets); | |
} | |
hueWrapper.appendChild(hueRangeField.element); | |
hueWrapper.appendChild(hueRange.element); | |
cpWrapper.className += " ytcenter-modules-cpwrapper"; | |
cpWrapper.appendChild(hueWrapper); | |
cpWrapper.appendChild(rgbWrapper); | |
dialog = ytcenter.dialog("COLORPICKER_TITLE", cpWrapper, [ | |
{ | |
label: "COLORPICKER_CANCEL", | |
primary: false, | |
callback: function(){ | |
rgb = ytcenter.utils.hexToColor(sessionHex); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
ytcenter.events.performEvent("ui-refresh"); | |
dialog.setVisibility(false); | |
} | |
}, { | |
label: "COLORPICKER_SAVE", | |
primary: true, | |
callback: function(){ | |
ytcenter.events.performEvent("ui-refresh"); | |
sessionHex = ytcenter.utils.colorToHex(red, green, blue); | |
if (bCallback) bCallback(sessionHex); | |
dialog.setVisibility(false); | |
} | |
} | |
]); | |
ytcenter.utils.addEventListener(wrapper, "click", function(){ | |
dialog.setVisibility(true); | |
ytcenter.events.performEvent("ui-refresh"); | |
ytcenter.events.performEvent("settings-update"); | |
update(); | |
}); | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
return { | |
element: wrapper, | |
bind: function(callback){ | |
bCallback = callback; | |
}, | |
update: function(value){ | |
sessionHex = value; | |
rgb = ytcenter.utils.hexToColor(sessionHex); | |
red = rgb.red; | |
green = rgb.green; | |
blue = rgb.blue; | |
update(); | |
updateColorField(); | |
updateHueRange(); | |
//ytcenter.events.performEvent("ui-refresh"); | |
} | |
}; | |
}; | |
ytcenter.modules.colorPickerField = function(option){ | |
function update() { | |
var x = sat/100*wrapper.clientWidth, | |
y = (100 - val)/100*wrapper.clientHeight; | |
handler.style.top = Math.round(y - handler.offsetHeight/2) + "px"; | |
if (ytcenter.ltr) { | |
handler.style.left = Math.round(x - handler.offsetWidth/2) + "px"; | |
} else { | |
handler.style.right = Math.round(wrapper.clientWidth - x - handler.offsetWidth/2) + "px"; | |
} | |
} | |
function updateBackground() { | |
wrapper.style.background = ytcenter.utils.hsvToHex(hue, 100, 100); | |
} | |
function eventToValue(e) { | |
if (e && e.type.indexOf("touched") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { | |
e = e.changedTouches[0]; | |
} | |
var offset = ytcenter.utils.getOffset(wrapper), | |
scrollOffset = ytcenter.utils.getScrollOffset(), | |
x = Math.max(0, Math.min(e.pageX - offset.left - scrollOffset.left, wrapper.clientWidth)), | |
y = e.pageY - offset.top - scrollOffset.top; | |
if (y < 0) y = 0; | |
if (y > wrapper.clientHeight) y = wrapper.clientHeight; | |
sat = x/wrapper.clientWidth*100; | |
val = 100 - y/wrapper.clientHeight*100; | |
} | |
function mousemove(e) { | |
if (!mousedown) return; | |
eventToValue(e); | |
update(); | |
if (bCallback) bCallback(sat, val); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function mousedownListener(e) { | |
if (mousedown) return; | |
mousedown = true; | |
eventToValue(e); | |
update(); | |
if (bCallback) bCallback(sat, val); | |
throttleFunc = ytcenter.utils.throttle(mousemove, 50); | |
ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false); | |
ytcenter.utils.addEventListener(document, "touchmove", throttleFunc, false); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function mouseupListener(e) { | |
if (!mousedown) return; | |
mousedown = false; | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "mousemove", throttleFunc, false); | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "touchmove", throttleFunc, false); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
var bCallback, | |
hue = (option && option.args && option.args.hue) || 0, | |
sat = (option && option.args && option.args.sat) || 0, | |
val = (option && option.args && option.args.val) || 0, | |
wrapper = document.createElement("div"), | |
_sat = document.createElement("div"), | |
_value = document.createElement("div"), | |
handler = document.createElement("div"), | |
mousedown = false, throttleFunc = null; | |
wrapper.style.background = ytcenter.utils.hsvToHex(hue, 100, 100); | |
wrapper.style.position = "relative"; // CLASS!! | |
wrapper.style.overflow = "hidden"; // CLASS!! | |
_sat.className = "ytcenter-modules-colorpicker-saturation"; | |
_value.className = "ytcenter-modules-colorpicker-value"; | |
_sat.appendChild(_value); | |
wrapper.appendChild(_sat); | |
handler.className = "ytcenter-modules-colorpicker-handler"; | |
wrapper.appendChild(handler); | |
ytcenter.utils.addEventListener(wrapper, "mousedown", mousedownListener); | |
ytcenter.utils.addEventListener(document, "mouseup", mouseupListener); | |
ytcenter.utils.addEventListener(wrapper, "touchstart", mousedownListener); | |
ytcenter.utils.addEventListener(document, "touchend", mouseupListener); | |
/*throttleFunc = ytcenter.utils.throttle(mousemove, 50); | |
ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false);*/ | |
ytcenter.events.addEvent("settings-update", function(){ | |
update(); | |
updateBackground(); | |
}); | |
update(); | |
updateBackground(); | |
return { | |
element: wrapper, | |
bind: function(callback){ | |
bCallback = callback; | |
}, | |
update: function(h, s, v){ | |
hue = h; | |
sat = s; | |
val = v; | |
update(); | |
updateBackground(); | |
} | |
}; | |
}; | |
ytcenter.modules.defaultplayersizedropdown = function(option){ | |
function getItemTitle(item) { | |
try { | |
var dim = ytcenter.utils.calculateDimensions(item.config.width, item.config.height); | |
if (typeof item.config.customName !== "undefined" && item.config.customName !== "") { | |
return item.config.customName; | |
} else if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")); | |
} else { | |
return dim[0] + "×" + dim[1]; | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
function getItemSubText(item) { | |
if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} else { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} | |
} | |
function setValue(id) { | |
selectedId = id; | |
if (selectedId === "default") { | |
btnLabel.textContent = ytcenter.language.getLocale("SETTINGS_RESIZE_DEFAULTPLAYERSIZE_DEFAULT"); | |
} else { | |
var item; | |
ytcenter.utils.each(items, function(i, val){ | |
if (val.id !== selectedId) return; | |
item = val; | |
return false; | |
}); | |
btnLabel.textContent = getItemTitle(item); | |
} | |
} | |
function defaultItem(db) { | |
if (typeof selectedId === "undefined") setValue("default"); | |
if ("default" === selectedId) { | |
setValue("default"); | |
} | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
var span = document.createElement("span"); | |
db.push(span); | |
span.className = "yt-uix-button-menu-item" + ("default" === selectedId ? " ytcenter-resize-dropdown-selected" : ""); | |
var title = document.createElement("span"); | |
title.textContent = ytcenter.language.getLocale("SETTINGS_RESIZE_DEFAULTPLAYERSIZE_DEFAULT"); | |
ytcenter.language.addLocaleElement(title, "SETTINGS_RESIZE_DEFAULTPLAYERSIZE_DEFAULT", "@textContent"); | |
title.style.display = "block"; | |
ytcenter.utils.addEventListener(li, "click", function(){ | |
if ("default" === selectedId) return; | |
setValue("default"); | |
ytcenter.utils.each(db, function(_i, elm){ | |
ytcenter.utils.removeClass(elm, "ytcenter-resize-dropdown-selected"); | |
}); | |
ytcenter.utils.addClass(span, "ytcenter-resize-dropdown-selected"); | |
if (saveCallback) saveCallback("default"); | |
try { | |
document.body.click(); | |
} catch (e) { | |
con.error(e); | |
} | |
}); | |
span.appendChild(title); | |
li.appendChild(span); | |
menu.appendChild(li); | |
} | |
function updateItems(_items) { | |
items = _items; | |
menu.innerHTML = ""; // Clearing it | |
var db = []; | |
defaultItem(db); | |
ytcenter.utils.each(items, function(i, item){ | |
if (typeof selectedId === "undefined") setValue(item.id); | |
if (item.id === selectedId) { | |
setValue(item.id); | |
} | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
var span = document.createElement("span"); | |
db.push(span); | |
span.className = "yt-uix-button-menu-item" + (item.id === selectedId ? " ytcenter-resize-dropdown-selected" : ""); | |
span.style.paddingBottom = "12px"; | |
var title = document.createElement("span"); | |
title.textContent = getItemTitle(item); | |
title.style.display = "block"; | |
title.style.fontWeight = "bold"; | |
var subtext = document.createElement("span"); | |
subtext.textContent = getItemSubText(item); | |
subtext.style.display = "block"; | |
subtext.style.fontSize = "11px"; | |
subtext.style.lineHeight = "0px"; | |
ytcenter.utils.addEventListener(li, "click", function(){ | |
if (item.id === selectedId) return; | |
setValue(item.id); | |
ytcenter.utils.each(db, function(_i, elm){ | |
ytcenter.utils.removeClass(elm, "ytcenter-resize-dropdown-selected"); | |
}); | |
ytcenter.utils.addClass(span, "ytcenter-resize-dropdown-selected"); | |
if (saveCallback) saveCallback(item.id); | |
try { | |
document.body.click(); | |
} catch (e) { | |
con.error(e); | |
} | |
}); | |
span.appendChild(title); | |
span.appendChild(subtext); | |
li.appendChild(span); | |
menu.appendChild(li); | |
}); | |
} | |
var saveCallback, selectedId = ytcenter.settings[option.defaultSetting], items, | |
wrapper = document.createElement("div"), | |
btnLabel = ytcenter.gui.createYouTubeButtonText("Player Sizes..."), | |
menu = document.createElement("ul"), | |
arrow = ytcenter.gui.createYouTubeButtonArrow(), | |
btn = ytcenter.gui.createYouTubeDefaultButton("", [btnLabel, arrow, menu]); | |
wrapper.style.display = "inline-block"; | |
btnLabel.style.display = "inline-block"; | |
btnLabel.style.width = "100%"; | |
menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid"; | |
menu.setAttribute("role", "menu"); | |
arrow.className += " ytcenter-arrow-fix"; | |
btn.className += " ytcenter-button-fix"; | |
btn.style.width = "175px"; | |
wrapper.appendChild(btn); | |
if (option.parent) { | |
option.parent.addEventListener("click", function(){ | |
selectedId = ytcenter.settings[option.defaultSetting]; | |
var opt = ytcenter.settings[option.args.bind], | |
found = false, i; | |
for (i = 0; i < opt.length; i++) { | |
if (opt[i].id === selectedId) found = true; | |
} | |
if (!found && selectedId !== "default") { | |
selectedId = opt[0].id; | |
if (saveCallback) saveCallback(selectedId); | |
} | |
updateItems(opt); | |
}); | |
} | |
return { | |
element: wrapper, // So the element can be appended to an element. | |
bind: function(callback){ | |
saveCallback = callback; | |
}, | |
update: function(v){ | |
selectedId = v; | |
var opt = ytcenter.settings[option.args.bind], | |
found = false, i; | |
for (i = 0; i < opt.length; i++) { | |
if (opt[i].id === selectedId) found = true; | |
} | |
if (!found && selectedId !== "default") { | |
selectedId = opt[0].id; | |
if (saveCallback) saveCallback(selectedId); | |
} | |
updateItems(opt); | |
} | |
}; | |
}; | |
ytcenter.modules.element = function(option){ | |
var elm = document.createElement(option && option.args && option.args.tagname); | |
if (option && option.args && option.args.style) { | |
for (var key in option.args.style) { | |
if (option.args.style.hasOwnProperty(key)) { | |
elm.style[key] = option.args.style[key]; | |
} | |
} | |
} | |
if (option && option.args && option.args.className) { | |
elm.className += " " + option.args.className; | |
} | |
if (option && option.args && option.args.text) { | |
elm.textContent = option.args.text; | |
} | |
if (option && option.args && option.args.html) { | |
con.error("[Settings Recipe] Element attribute HTML not allowed!"); | |
} | |
if (option && option.args && option.args.load) { | |
tab.addEventListener("click", function(){ | |
option.args.load.apply(null, [elm]); | |
}); | |
} | |
if (option && option.args && option.args.listeners) { | |
for (var i = 0; i < option.args.listeners.length; i++) { | |
elm.addEventListener(option.args.listeners[i].event, option.args.listeners[i].callback, (option.args.listeners[i].bubble ? option.args.listeners[i].bubble : false)); | |
} | |
} | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.importexport = function(){ | |
function settingsPoolChecker(){ | |
function success() { | |
dialog.getActionButton("save").disabled = false; | |
settingsPool.style.background = ""; | |
saveEnabled = true; | |
} | |
function fail() { | |
dialog.getActionButton("save").disabled = true; | |
settingsPool.style.background = "#FFAAAA"; | |
saveEnabled = false; | |
} | |
try { | |
var data = JSON.parse(settingsPool.value); | |
if (typeof data === "object" && !!data) { | |
success(); | |
} else { | |
fail(); | |
} | |
} catch (e) { | |
fail(); | |
} | |
} | |
var textLabel = ytcenter.gui.createYouTubeButtonTextLabel("SETTINGS_IMEX_TITLE"), | |
content = document.createElement("div"), | |
VALIDATOR_STRING = "YTCSettings=>", | |
dropZone = document.createElement("div"), | |
dropZoneContent = document.createElement("div"), | |
filechooser = document.createElement("input"), | |
settingsPool = document.createElement("textarea"), | |
dialog = ytcenter.dialog("SETTINGS_IMEX_TITLE", content, [ | |
{ | |
label: "SETTINGS_IMEX_CANCEL", | |
primary: false, | |
callback: function(){ | |
dialog.setVisibility(false); | |
} | |
}, { | |
name: "save", | |
label: "SETTINGS_IMEX_SAVE", | |
primary: true, | |
callback: function(){ | |
if (!saveEnabled) return; | |
ytcenter.settings = JSON.parse(settingsPool.value); | |
ytcenter.settings.lastUpdated = ytcenter.utils.now(); | |
ytcenter.saveSettings(false, function(){ | |
loc.reload(); | |
}); | |
dialog.setButtonsEnabled(false); | |
} | |
} | |
]), | |
status, | |
loadingText = document.createElement("div"), | |
messageText = document.createElement("div"), | |
messageTimer, | |
dropZoneEnabled = true, | |
saveEnabled = true, | |
pushMessage = function(message, color, timer){ | |
//dropZoneEnabled = false; | |
messageText.textContent = message; | |
messageText.style.display = "inline-block"; | |
if (typeof color === "string") messageText.style.color = color; | |
else messageText.style.color = ""; | |
status.style.display = ""; | |
dropZoneContent.style.visibility = "hidden"; | |
uw.clearTimeout(messageTimer); | |
if (typeof timer === "number") { | |
messageTimer = uw.setTimeout(function(){ | |
removeMessage(); | |
}, timer); | |
} | |
}, | |
removeMessage = function(){ | |
status.style.display = "none"; | |
dropZoneContent.style.visibility = ""; | |
messageText.style.display = "none"; | |
messageText.textContent = ""; | |
//dropZoneEnabled = true; | |
uw.clearTimeout(messageTimer); | |
}, | |
validateFileAndLoad = function(file){ | |
dropZone.style.border = "2px dashed rgb(187, 187, 187)"; | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_VALIDATE")); | |
var reader = new FileReader(); | |
reader.onerror = function(e){ | |
switch (e.target.error.code) { | |
case e.target.error.NOT_FOUND_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_NOT_FOUND"), "#ff0000", 10000); | |
break; | |
case e.target.error.NOT_READABLE_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_NOT_READABLE"), "#ff0000", 10000); | |
break; | |
case e.target.error.ABORT_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_ABORT"), "#ff0000", 10000); | |
break; | |
default: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_UNKNOWN"), "#ff0000", 10000); | |
break; | |
} | |
}; | |
reader.onabort = function(){ | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_ABORT"), "#ff0000", 10000); | |
}; | |
reader.onload = function(e){ | |
if (e.target.result === VALIDATOR_STRING) { | |
readFile(file, true); | |
} else { | |
readFile(file, false); | |
//pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_VALIDATE_ERROR_NOT_VALID"), "#ff0000", 3500); | |
} | |
}; | |
// Checking the filename | |
try { | |
if (file.name.indexOf(".ytcs") !== file.name.length - ".ytcs".length) { | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_VALIDATE_ERROR_NOT_VALID"), "#ff0000", 3500); | |
return; | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
reader.readAsText(file.slice(0, VALIDATOR_STRING.length)); | |
}, | |
readFile = function(file, hasPrefix){ | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_LOADING")); | |
var reader = new FileReader(); | |
reader.onerror = function(e){ | |
switch (e.target.error.code) { | |
case e.target.error.NOT_FOUND_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_NOT_FOUND"), "#ff0000", 10000); | |
break; | |
case e.target.error.NOT_READABLE_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_NOT_READABLE"), "#ff0000", 10000); | |
break; | |
case e.target.error.ABORT_ERR: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_ABORT"), "#ff0000", 10000); | |
break; | |
default: | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_UNKNOWN"), "#ff0000", 10000); | |
break; | |
} | |
}; | |
reader.onabort = function(){ | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_ERROR_ABORT"), "#ff0000", 10000); | |
}; | |
reader.onload = function(e){ | |
var content = e.target.result; | |
try { | |
// Validate JSON | |
JSON.parse(content); | |
} catch (e) { | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_VALIDATE_ERROR_NOT_VALID"), "#ff0000", 3500); | |
return; | |
} | |
settingsPool.value = content; | |
pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_MESSAGE"), "", 10000); | |
settingsPoolChecker(); | |
}; | |
if (hasPrefix) { | |
reader.readAsText(file.slice(VALIDATOR_STRING.length)); | |
} else { | |
reader.readAsText(file); | |
} | |
}, | |
exportFileButtonLabel = ytcenter.gui.createYouTubeButtonTextLabel("SETTINGS_IMEX_EXPORT_AS_FILE"), | |
exportFileButton = ytcenter.gui.createYouTubeDefaultButton("", [exportFileButtonLabel]), | |
statusContainer = document.createElement("div"); | |
var elm = ytcenter.gui.createYouTubeDefaultButton("", [textLabel]); | |
// Message Text | |
messageText.style.fontWeight = "bold"; | |
messageText.style.fontSize = "16px"; | |
messageText.style.textAlign = "center"; | |
messageText.style.width = "100%"; | |
messageText.style.display = "none"; | |
status = ytcenter.gui.createMiddleAlignHack(messageText); | |
status.style.position = "absolute"; | |
status.style.top = "0px"; | |
status.style.left = "0px"; | |
status.style.width = "100%"; | |
status.style.height = "100%"; | |
status.style.display = "none"; | |
filechooser.setAttribute("type", "file"); | |
ytcenter.utils.addEventListener(elm, "click", function(){ | |
dialog.setVisibility(true); | |
}, false); | |
var __f = function(e){ | |
validateFileAndLoad(e.target.files[0]); | |
var newNode = document.createElement("input"); | |
newNode.setAttribute("type", "file"); | |
ytcenter.utils.addEventListener(newNode, "change", __f, false); | |
filechooser.parentNode.replaceChild(newNode, filechooser); | |
filechooser = newNode; | |
}; | |
ytcenter.utils.addEventListener(filechooser, "change", __f, false); | |
ytcenter.utils.addEventListener(dropZone, "drop", function(e){ | |
e.stopPropagation(); | |
e.preventDefault(); | |
validateFileAndLoad(e.dataTransfer.files[0]); | |
}, false); | |
ytcenter.utils.addEventListener(dropZone, "dragover", function(e){ | |
if (!dropZoneEnabled) return; | |
e.stopPropagation(); | |
e.preventDefault(); | |
e.dataTransfer.dropEffect = "copy"; | |
dropZone.style.border = "2px dashed rgb(130, 130, 130)"; | |
}, false); | |
ytcenter.utils.addEventListener(dropZone, "dragleave", function(e){ | |
if (!dropZoneEnabled) return; | |
dropZone.style.border = "2px dashed rgb(187, 187, 187)"; | |
e.dataTransfer.dropEffect = "none"; | |
}, false); | |
ytcenter.utils.addEventListener(dropZone, "dragend", function(e){ | |
if (!dropZoneEnabled) return; | |
dropZone.style.border = "2px dashed rgb(187, 187, 187)"; | |
e.dataTransfer.dropEffect = "none"; | |
}, false); | |
var text1 = document.createElement("span"); | |
text1.style.fontWeight = "bold"; | |
text1.style.fontSize = "16px"; | |
text1.textContent = ytcenter.language.getLocale("SETTINGS_IMEX_DROPFILEHERE"); | |
ytcenter.language.addLocaleElement(text1, "SETTINGS_IMEX_DROPFILEHERE", "@textContent"); | |
dropZoneContent.appendChild(text1); | |
dropZoneContent.appendChild(document.createElement("br")); | |
var text2 = document.createTextNode(ytcenter.language.getLocale("SETTINGS_IMEX_OR")); | |
ytcenter.language.addLocaleElement(text2, "SETTINGS_IMEX_OR", "@textContent"); | |
dropZoneContent.appendChild(text2); | |
dropZoneContent.appendChild(document.createTextNode(" ")); | |
dropZoneContent.appendChild(filechooser); | |
dropZone.style.position = "relative"; | |
dropZone.style.border = "2px dashed rgb(187, 187, 187)"; | |
dropZone.style.borderRadius = "4px"; | |
dropZone.style.color = "rgb(110, 110, 110)"; | |
dropZone.style.padding = "20px 0"; | |
dropZone.style.width = "100%"; | |
dropZone.style.marginBottom = "10px"; | |
dropZone.style.textAlign = "center"; | |
settingsPool.style.width = "100%"; | |
settingsPool.style.height = "120px"; | |
dropZoneContent.style.margin = "0 auto"; | |
dropZoneContent.style.display = "inline-block"; | |
if (ytcenter.ltr) { | |
dropZoneContent.style.textAlign = "left"; | |
} else { | |
dropZoneContent.style.textAlign = "right"; | |
} | |
dropZone.appendChild(dropZoneContent); | |
dropZone.appendChild(status); | |
content.appendChild(dropZone); | |
content.appendChild(settingsPool); | |
dialog.setWidth("490px"); | |
ytcenter.utils.addEventListener(settingsPool, "input", settingsPoolChecker, false); | |
ytcenter.utils.addEventListener(settingsPool, "keyup", settingsPoolChecker, false); | |
ytcenter.utils.addEventListener(settingsPool, "paste", settingsPoolChecker, false); | |
ytcenter.utils.addEventListener(settingsPool, "change", settingsPoolChecker, false); | |
dialog.addEventListener("visibility", function(visible){ | |
if (visible) settingsPool.value = JSON.stringify(ytcenter.settings); | |
else settingsPool.value = ""; | |
settingsPoolChecker(); | |
}); | |
ytcenter.utils.addEventListener(exportFileButton, "click", function(){ | |
try { | |
var blob = new ytcenter.unsafe.io.Blob([ JSON.stringify(ytcenter.settings) ], { "type": "application/octet-stream" }); | |
ytcenter.unsafe.io.saveAs(blob, "ytcenter-settings.ytcs"); | |
} catch (e) { | |
con.error(e); | |
} | |
}, false); | |
content.appendChild(exportFileButton); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.label = function(option){ | |
var frag = document.createDocumentFragment(), | |
text = document.createTextNode(ytcenter.language.getLocale(option.label)); | |
frag.appendChild(text); | |
ytcenter.language.addLocaleElement(text, option.label, "@textContent"); | |
return { | |
element: frag, // So the element can be appended to an element. | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.line = function(){ | |
var frag = document.createDocumentFragment(), | |
hr = document.createElement("hr"); | |
hr.className = "yt-horizontal-rule"; | |
frag.appendChild(hr); | |
return { | |
element: frag, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.link = function(option){ | |
var elm = document.createElement("div"), | |
title = document.createElement("b"); | |
if (option && option.args && option.args.titleLocale) { | |
var __t1 = document.createTextNode(ytcenter.language.getLocale(option.args.titleLocale)), | |
__t2 = document.createTextNode(":"); | |
ytcenter.language.addLocaleElement(__t1, option.args.titleLocale, "@textContent", option.args.replace || {}); | |
title.appendChild(__t1); | |
title.appendChild(__t2); | |
} else if (option && option.args && option.args.title) { | |
title.textContent = option.args.title + ":"; | |
} | |
var content = document.createElement("div"); | |
content.className = "ytcenter-modules-links"; | |
for (var i = 0; i < option.args.links.length; i++) { | |
if (i > 0) content.appendChild(document.createElement("br")); | |
var __a = document.createElement("a"); | |
__a.href = option.args.links[i].url; | |
__a.textContent = option.args.links[i].text; | |
__a.setAttribute("target", "_blank"); | |
content.appendChild(__a); | |
} | |
elm.appendChild(title); | |
elm.appendChild(content); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.list = function(option){ | |
function update(value) { | |
var i; | |
for (i = 0; i < s.options.length; i++) { | |
if (s.options[i].value === value) { | |
s.selectedIndex = i; | |
break; | |
} | |
} | |
} | |
function bind(callback) { | |
cCallback = callback; | |
} | |
var frag = document.createDocumentFragment(), | |
elm = document.createElement("span"), | |
sc = document.createElement("span"), | |
defaultLabel, s = document.createElement("select"), | |
list = [], defaultLabelText, | |
sc1 = document.createElement("img"), | |
sc2 = document.createElement("span"), | |
cCallback; | |
elm.className = "yt-uix-form-input-select"; | |
sc.className = "yt-uix-form-input-select-content"; | |
s.className = "yt-uix-form-input-select-element"; | |
s.style.cursor = "pointer"; | |
if (typeof option.args.list === "function") { | |
list = option.args.list(); | |
} else { | |
list = option.args.list; | |
} | |
if (list && list.length > 0) { | |
defaultLabelText = ytcenter.language.getLocale(list[0].label); | |
for (var i = 0; i < list.length; i++) { | |
var item = document.createElement("option"); | |
item.value = list[i].value; | |
if (typeof list[i].label === "function") { | |
item.textContent = list[i].label(); | |
} else if (typeof list[i].label !== "undefined") { | |
item.textContent = ytcenter.language.getLocale(list[i].label); | |
ytcenter.language.addLocaleElement(item, list[i].label, "@textContent"); | |
} | |
if (list[i].value === ytcenter.settings[option.defaultSetting]) { | |
item.selected = true; | |
defaultLabelText = item.textContent; | |
} | |
s.appendChild(item); | |
} | |
sc1.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; | |
sc1.className = "yt-uix-form-input-select-arrow"; | |
sc.appendChild(sc1); | |
sc2.className = "yt-uix-form-input-select-value"; | |
sc2.textContent = defaultLabelText; | |
sc.appendChild(sc2); | |
ytcenter.events.addEvent("language-refresh", function(){ | |
sc2.textContent = s.options[s.selectedIndex].textContent; | |
}); | |
ytcenter.utils.addEventListener(s, "change", function(){ | |
sc2.textContent = s.options[s.selectedIndex].textContent; | |
if (cCallback) cCallback(s.value); | |
if (option && option.args && option.args.listeners) { | |
for (var i = 0; i < option.args.listeners.length; i++) { | |
if (option.args.listeners[i].event === "update") { | |
option.args.listeners[i].callback(); | |
} else { | |
con.error("[Module:List] Unknown event " + option.args.listeners[i].event); | |
} | |
} | |
} | |
}, false); | |
} | |
elm.appendChild(sc); | |
elm.appendChild(s); | |
frag.appendChild(elm); | |
return { | |
element: frag, | |
bind: bind, | |
update: update | |
}; | |
}; | |
ytcenter.modules.multilist = function(option){ | |
function fixList(_settingData) { | |
if (_settingData === "") return ""; | |
var a = _settingData.split("&"), b = [], c = [], d, i; | |
for (i = 0; i < list.length; i++) { | |
c.push(list[i].value); | |
} | |
for (i = 0; i < a.length; i++) { | |
if (a[i] !== "") { | |
d = decodeURIComponent(a[i]); | |
if ($ArrayIndexOf(c, d) !== -1 && $ArrayIndexOf(b, d) === -1) { | |
b.push(a[i]); | |
} | |
} | |
} | |
return b.join("&"); | |
} | |
function saveItem(value) { | |
if (settingData === "") return encodeURIComponent(value); | |
var a = settingData.split("&"), i; | |
for (i = 0; i < a.length; i++) { | |
if (decodeURIComponent(a[i]) === value) return; | |
} | |
a.push(encodeURIComponent(value)); | |
return a.join("&"); | |
} | |
function removeItem(value) { | |
if (settingData === "") return encodeURIComponent(value); | |
var a = settingData.split("&"), b = [], i; | |
for (i = 0; i < a.length; i++) { | |
if (decodeURIComponent(a[i]) !== value) { | |
b.push(a[i]); | |
} | |
} | |
return b.join("&"); | |
} | |
function isEnabled(value) { | |
if (settingData === "") return false; | |
var a = settingData.split("&"), i; | |
for (i = 0; i < a.length; i++) { | |
if (decodeURIComponent(a[i]) === value) return true; | |
} | |
return false; | |
} | |
function createItem(label, value) { | |
var s = document.createElement("label"), | |
cb = ytcenter.modules.checkbox(isEnabled(value)), | |
text = document.createTextNode(ytcenter.language.getLocale(label)); | |
ytcenter.language.addLocaleElement(text, label, "@textContent"); | |
cb.bind(function(checked){ | |
if (checked) { | |
settingData = saveItem(value); | |
} else { | |
settingData = removeItem(value); | |
} | |
if (typeof saveCallback === "function") saveCallback(settingData); | |
callbackListeners(); | |
}); | |
cb.element.style.marginRight = "6px"; | |
s.appendChild(cb.element); | |
s.appendChild(text); | |
return s; | |
} | |
function updateList() { | |
var d, item; | |
settingData = fixList(settingData); | |
wrapper.innerHTML = ""; | |
for (var i = 0; i < list.length; i++) { | |
d = document.createElement("div"); | |
item = createItem(list[i].label, list[i].value); | |
d.appendChild(item); | |
wrapper.appendChild(d); | |
} | |
} | |
function callbackListeners() { | |
var i; | |
if (option.args.listeners && option.args.listeners) { | |
for (i = 0; i < option.args.listeners.length; i++) { | |
if (option.args.listeners[i].event === "click") { | |
option.args.listeners[i].callback(); | |
} | |
} | |
} | |
} | |
var list = (option && option.args && option.args.list) || [], | |
settingData, wrapper = document.createElement("div"), saveCallback; | |
wrapper.style.paddingLeft = "16px"; | |
settingData = ytcenter.settings[option.defaultSetting]; | |
updateList(); | |
return { | |
element: wrapper, | |
update: function(data){ | |
settingData = data; | |
updateList(); | |
}, | |
bind: function(a){ | |
saveCallback = a; | |
} | |
}; | |
}; | |
ytcenter.modules.newline = function(option){ | |
var elm = document.createElement("br"); | |
if (option && option.args && option.args.style) { | |
for (var key in option.args.style) { | |
if (option.args.style.hasOwnProperty(key)) { | |
elm.style[key] = option.args.style[key]; | |
} | |
} | |
} | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.placement = function(args){ | |
function createListItem(content) { | |
var a = document.createElement("li"); | |
a.className = "ytcenter-module-placement-item"; | |
a.textContent = content; | |
return a; | |
} | |
var template = [ | |
{ | |
"type": "block", | |
"id": "player", | |
"prepend": true, | |
"insert": false, | |
"append": false, | |
"content": "Player" | |
}, { | |
"type": "interactive", | |
"id": "watch7-headline", | |
"prepend": true, | |
"insert": true, | |
"append": false | |
}, { | |
"type": "interactive", | |
"id": "watch7-sentiment-actions", | |
"prepend": true, | |
"insert": true, | |
"append": false | |
} | |
], | |
predefinedElements = [ | |
{ | |
"parent": "watch7-sentiment-actions", | |
"id": "like-button-renderer", | |
"content": "Like/Dislike" | |
}, { | |
"parent": "watch7-headline", | |
"id": "watch-headline-title", | |
"content": "TITLE" | |
} | |
]; | |
var elm = document.createElement("div"), i, j, a, b, c; | |
for (i = 0; i < template.length; i++) { | |
a = document.createElement("ol"); | |
if (template[i].type === "interactive") { | |
a.className = "ytcenter-moduel-placement-interactive"; | |
} else if (template[i].type === "block") { | |
a.className = "ytcenter-moduel-placement-block"; | |
} else if (template[i].type === "hidden") { | |
a.className = "ytcenter-moduel-placement-hidden"; | |
} | |
if (template[i].content) a.textContent = template[i].content; | |
if (template[i].prepend) { | |
b = document.createElement("ol"); | |
b.className = "ytcenter-moduel-placement-empty"; | |
b.textContent = "+"; | |
elm.appendChild(b); | |
} | |
if (template[i].insert) { | |
for (j = 0; j < predefinedElements.length; j++) { | |
if (predefinedElements[j].parent === template[i].id) { | |
c = createListItem(predefinedElements[j].content); | |
a.appendChild(c); | |
} | |
} | |
} | |
elm.appendChild(a); | |
if (template[i].append) { | |
b = document.createElement("ol"); | |
b.className = "ytcenter-moduel-placement-empty"; | |
b.textContent = "+"; | |
elm.appendChild(b); | |
} | |
} | |
return { | |
element: elm, | |
update: function(){}, | |
bind: function(){} | |
}; | |
}; | |
ytcenter.modules.range = function(option){ | |
function setValue(val) { | |
if (val === options.value) return; | |
if (options.step !== 0) { | |
var diff = val%options.step; | |
if (diff >= options.step/2 && (options.step-diff)+val <= options.max) { | |
options.value = (options.step-diff)+val; | |
} else { | |
options.value = val - diff; | |
} | |
} else { | |
options.value = val; | |
} | |
update(); | |
if (options.value > options.max) { | |
setValue(options.max); | |
return; | |
} | |
if (options.value < options.min) { | |
setValue(options.min); | |
return; | |
} | |
}; | |
function update() { | |
if (options.method === "vertical") { | |
handle.style.top = ((options.value - options.min)/(options.max - options.min)*(wrapper.clientHeight - handle.offsetHeight)) + "px"; | |
} else { | |
handle.style.left = ((options.value - options.min)/(options.max - options.min)*(wrapper.clientWidth - handle.offsetWidth)) + "px"; | |
handle.style.right = ((options.value - options.min)/(options.max - options.min)*(wrapper.clientWidth - handle.offsetWidth)) + "px"; | |
} | |
} | |
function eventToValue(e) { | |
var offset = ytcenter.utils.getOffset(wrapper), | |
scrollOffset = ytcenter.utils.getScrollOffset(), | |
v, l; | |
if (e && e.type.indexOf("touch") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { | |
e = e.changedTouches[0]; | |
} | |
if (options.method === "vertical") { | |
offset.top += options.offset; | |
v = e.pageY - scrollOffset.top - offset.top; | |
l = v + parseInt(options.height)/2 - 3; | |
if (l < 0) l = 0; | |
if (l > wrapper.clientHeight - handle.clientHeight) l = wrapper.clientHeight - handle.clientHeight; | |
setValue(l/(wrapper.clientHeight - handle.clientHeight)*(options.max - options.min) + options.min); | |
} else { | |
offset.left += options.offset; | |
v = e.pageX - scrollOffset.left - offset.left; | |
l = v - parseInt(options.height)/2; | |
if (l < 0) l = 0; | |
if (l > wrapper.clientWidth - handle.clientWidth) l = wrapper.clientWidth - handle.clientWidth; | |
if (!ytcenter.ltr) l = (wrapper.clientWidth - handle.clientWidth) - l; | |
setValue(l/(wrapper.clientWidth - handle.clientWidth)*(options.max - options.min) + options.min); | |
} | |
update(); | |
} | |
function mousemove(e){ | |
if (!mousedown) return; | |
eventToValue(e); | |
if (bCallback) bCallback(options.value); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function initListeners() { | |
/* Mouse */ | |
ytcenter.utils.addEventListener(wrapper, "mousedown", mousedownListener); | |
ytcenter.utils.addEventListener(document, "mouseup", mouseupListener); | |
/* Touch */ | |
ytcenter.utils.addEventListener(wrapper, "touchstart", mousedownListener); | |
ytcenter.utils.addEventListener(document, "touchend", mouseupListener); | |
} | |
function unloadListeners() { | |
/* Mouse */ | |
ytcenter.utils.removeEventListener(wrapper, "mousedown", mousedownListener); | |
ytcenter.utils.removeEventListener(document, "mouseup", mouseupListener); | |
/* Touch */ | |
ytcenter.utils.removeEventListener(wrapper, "touchstart", mousedownListener); | |
ytcenter.utils.removeEventListener(document, "touchend", mouseupListener); | |
} | |
function mouseupListener(e) { | |
if (!mousedown) return; | |
mousedown = false; | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "mousemove", throttleFunc, false); | |
if (throttleFunc) ytcenter.utils.removeEventListener(document, "touchmove", throttleFunc, false); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
function mousedownListener(e) { | |
if (mousedown) return; | |
mousedown = true; | |
eventToValue(e); | |
if (bCallback) bCallback(options.value); | |
throttleFunc = ytcenter.utils.throttle(mousemove, 50); | |
ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false); | |
ytcenter.utils.addEventListener(document, "touchmove", throttleFunc, false); | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
} | |
var options = ytcenter.utils.mergeObjects({ | |
value: 0, | |
min: 0, | |
max: 100, | |
step: 1, | |
width: "225px", | |
height: "14px", | |
method: "horizontal", // horizontal, vertical | |
handle: null, | |
offset: 0 | |
}, option.args), | |
handle, mousedown = false, bCallback, | |
wrapper = document.createElement("span"), | |
throttleFunc = null; | |
wrapper.className = "ytcenter-modules-range"; | |
if (options.method === "vertical") { | |
wrapper.style.width = options.height; | |
wrapper.style.height = options.width; | |
} else { | |
wrapper.style.width = options.width; | |
wrapper.style.height = options.height; | |
} | |
if (options.handle) { | |
handle = options.handle; | |
} else { | |
handle = document.createElement("div"); | |
handle.className = "ytcenter-modules-range-handle"; | |
handle.style.width = (parseInt(options.height)) + "px"; | |
handle.style.height = parseInt(options.height) + "px"; | |
} | |
wrapper.appendChild(handle); | |
if (option.parent) { | |
option.parent.addEventListener("click", function(){ | |
setValue(options.value); | |
update(); | |
}); | |
} | |
setValue(options.value); | |
update(); | |
initListeners(); | |
return { | |
element: wrapper, | |
bind: function(callback){ | |
bCallback = callback; | |
}, | |
update: function(value){ | |
setValue(value); | |
update(); | |
}, | |
getValue: function(){ | |
return options.value; | |
} | |
}; | |
}; | |
ytcenter.modules.rangetext = function(option){ | |
function getValue(text) { | |
if (prefixSuffixActive) { | |
if (option.args.prefix && option.args.prefix !== "") { | |
if (text.indexOf(option.args.prefix) === 0) | |
text = text.substring(option.args.prefix.length); | |
} | |
if (option.args.suffix && option.args.suffix !== "") { | |
if (text.indexOf(option.args.suffix) === text.length - option.args.suffix.length) | |
text = text.substring(0, text.length - option.args.suffix.length); | |
} | |
} | |
text = parseInt(text, 10); | |
if (isNaN(text) || text === Infinity) text = 0; | |
return text; | |
} | |
function update() { | |
_text.value = (option.args.prefix ? option.args.prefix : "") + Math.round(range.getValue()) + (option.args.suffix ? option.args.suffix : ""); | |
prefixSuffixActive = true; | |
} | |
var range = ytcenter.modules.range(option), | |
wrapper = document.createElement("div"), | |
bCallback, prefixSuffixActive = true; | |
wrapper.style.display = "inline-block"; | |
wrapper.appendChild(range.element); | |
var _text = document.createElement("input"); | |
_text.setAttribute("type", "text"); | |
_text.value = Math.round(range.getValue()); | |
_text.className = "ytcenter-modules-rangetext"; | |
if (option.args["text-width"]) { | |
_text.style.width = option.args["text-width"]; | |
} | |
wrapper.appendChild(_text); | |
range.bind(function(value){ | |
update(); | |
if (bCallback) bCallback(value); | |
}); | |
if (option.parent) { | |
option.parent.addEventListener("click", function(){ | |
update(); | |
}); | |
} | |
_text.addEventListener("focus", function(){ | |
var val = getValue(this.value); | |
range.update(val); | |
var sel = ytcenter.utils.getCaretPosition(this); | |
this.value = val; | |
prefixSuffixActive = false; | |
ytcenter.utils.setCaretPosition(this, sel); | |
this.setSelectionRange(); | |
}, false); | |
_text.addEventListener("blur", function(){ | |
var val = getValue(this.value); | |
range.update(val); | |
val = range.getValue(); | |
if (bCallback) bCallback(val); | |
update(); | |
}, false); | |
_text.addEventListener("input", function(){ | |
var val = getValue(this.value); | |
range.update(val); | |
}, false); | |
_text.addEventListener("change", function(){ | |
var val = getValue(this.value); | |
range.update(val); | |
val = range.getValue(); | |
if (bCallback) bCallback(val); | |
update(); | |
}, false); | |
return { | |
element: wrapper, | |
bind: function(callback){ | |
var a = null, | |
b = false, | |
c = null; | |
bCallback = function(value){ | |
c = value; | |
if (b) { | |
return; | |
} | |
b = true; | |
uw.clearTimeout(a); | |
a = uw.setTimeout(function(){ | |
callback(c); | |
b = false; | |
}, 500); | |
}; | |
}, | |
update: function(value){ | |
range.update(value); | |
update(); | |
}, | |
getValue: function(){ | |
return range.getValue(); | |
} | |
}; | |
}; | |
ytcenter.modules.resizedropdown = function(option){ | |
function getItemTitle(item) { | |
var dim = ytcenter.utils.calculateDimensions(item.config.width, item.config.height); | |
if (typeof item.config.customName !== "undefined" && item.config.customName !== "") { | |
return item.config.customName; | |
} else if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")); | |
subtext.textContent = (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER")); | |
} else { | |
return dim[0] + "×" + dim[1]; | |
subtext.textContent = (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER")); | |
} | |
} | |
function getItemSubText(item) { | |
if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { | |
return ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} else { | |
return (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} | |
} | |
function setValue(id) { | |
selectedId = id; | |
var item; | |
ytcenter.utils.each(items, function(i, val){ | |
if (val.id !== selectedId) return; | |
item = val; | |
return false; | |
}); | |
btnLabel.textContent = getItemTitle(item); | |
} | |
function updateItems(_items) { | |
items = _items; | |
menu.innerHTML = ""; // Clearing it | |
var db = []; | |
ytcenter.utils.each(items, function(i, item){ | |
if (typeof selectedId === "undefined") setValue(item.id); | |
if (item.id === selectedId) { | |
setValue(item.id); | |
} | |
var li = document.createElement("li"); | |
li.setAttribute("role", "menuitem"); | |
var span = document.createElement("span"); | |
db.push(span); | |
span.className = "yt-uix-button-menu-item" + (item.id === selectedId ? " ytcenter-resize-dropdown-selected" : ""); | |
span.style.paddingBottom = "12px"; | |
var title = document.createElement("span"); | |
title.textContent = getItemTitle(item); | |
title.style.display = "block"; | |
title.style.fontWeight = "bold"; | |
var subtext = document.createElement("span"); | |
subtext.textContent = getItemSubText(item); | |
subtext.style.display = "block"; | |
subtext.style.fontSize = "11px"; | |
subtext.style.lineHeight = "0px"; | |
ytcenter.utils.addEventListener(li, "click", function(){ | |
if (item.id === selectedId) return; | |
setValue(item.id); | |
ytcenter.utils.each(db, function(_i, elm){ | |
ytcenter.utils.removeClass(elm, "ytcenter-resize-dropdown-selected"); | |
}); | |
ytcenter.utils.addClass(span, "ytcenter-resize-dropdown-selected"); | |
if (saveCallback) saveCallback(item.id); | |
try { | |
document.body.click(); | |
} catch (e) { | |
con.error(e); | |
} | |
}); | |
span.appendChild(title); | |
span.appendChild(subtext); | |
li.appendChild(span); | |
menu.appendChild(li); | |
}); | |
} | |
var saveCallback; | |
var selectedId; | |
var items; | |
var wrapper = document.createElement("div"); | |
wrapper.className = "ytcenter-embed"; | |
var btnLabel = ytcenter.gui.createYouTubeButtonText("Player Sizes..."); | |
btnLabel.style.display = "inline-block"; | |
btnLabel.style.width = "100%"; | |
var menu = document.createElement("ul"); | |
menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid"; | |
menu.setAttribute("role", "menu"); | |
var arrow = ytcenter.gui.createYouTubeButtonArrow(); | |
arrow.style.marginLeft = "-10px"; | |
var btn = ytcenter.gui.createYouTubeDefaultButton("", [btnLabel, arrow, menu]); | |
btn.style.width = "175px"; | |
btn.style.textAlign = "left"; | |
wrapper.appendChild(btn); | |
updateItems(ytcenter.settings[option.defaultSetting]); | |
if (option.parent) { | |
option.parent.addEventListener("click", function(){ | |
var opt = ytcenter.settings[option.defaultSetting]; | |
var found = false; | |
for (var i = 0; i < opt.length; i++) { | |
if (opt[i].id === selectedId) found = true; | |
} | |
if (!found) { | |
selectedId = opt[0].id; | |
if (saveCallback) saveCallback(selectedId); | |
} | |
updateItems(opt); | |
}); | |
} | |
return { | |
element: wrapper, // So the element can be appended to an element. | |
bind: function(callback){ | |
saveCallback = callback; | |
}, | |
update: function(v){ | |
selectedId = v; | |
updateItems(items); | |
} | |
}; | |
}; | |
ytcenter.modules.resizeItemList = function(option){ | |
function wrapItem(item) { | |
if (typeof item.getItemElement !== "undefined") return item; // It's already been processed | |
var selected = false; | |
var li = document.createElement("li"); | |
li.className = "ytcenter-list-item ytcenter-dragdrop-item"; | |
var order = document.createElement("div"); | |
order.className = "ytcenter-dragdrop-handle"; | |
var content = document.createElement("div"); | |
content.className = "ytcenter-list-item-content"; | |
var title = document.createElement("span"); | |
title.className = "ytcenter-list-item-title"; | |
var subtext = document.createElement("span"); | |
subtext.className = "ytcenter-list-item-subtext"; | |
content.appendChild(title); | |
content.appendChild(subtext); | |
li.appendChild(order); | |
li.appendChild(content); | |
ytcenter.utils.addEventListener(content, "click", function(){ | |
if (selected) return; | |
selectSizeItem(item.id); | |
}); | |
var out = { | |
getId: function(){ | |
return item.id; | |
}, | |
getData: function(){ | |
return item; | |
}, | |
getConfig: function(){ | |
return item.config; | |
}, | |
setConfig: function(conf){ | |
item.config = conf; | |
}, | |
updateItemElement: function(){ | |
var dim = ytcenter.utils.calculateDimensions(item.config.width, item.config.height); | |
title.textContent = getItemTitle(out); | |
subtext.textContent = getItemSubText(out); | |
}, | |
getItemElement: function(){ | |
return li; | |
}, | |
select: function(){ | |
if (selected) return; | |
selectSizeItem(item.id); | |
}, | |
setSelection: function(_selected){ | |
selected = _selected; | |
if (selected) { | |
ytcenter.utils.addClass(li, "ytcenter-list-item-selected"); | |
} else { | |
ytcenter.utils.removeClass(li, "ytcenter-list-item-selected"); | |
} | |
} | |
}; | |
out.updateItemElement(); | |
ytcenter.events.addEvent("ui-refresh", function(){ | |
out.updateItemElement(); | |
}); | |
return out; | |
} | |
function getItemInfo(item) { | |
var exports = {}; | |
var dim = ytcenter.utils.calculateDimensions(item.getConfig().width, item.getConfig().height); | |
if (item.getConfig().width === "" && item.getConfig().height === "") { | |
exports.width = ""; | |
exports.height = ""; | |
} else { | |
if (typeof dim[0] === "number" && !isNaN(parseInt(item.getConfig().width))) { | |
exports.width = dim[0] + "px"; | |
} else if (!isNaN(parseInt(item.getConfig().width))) { | |
exports.width = dim[0]; | |
} else { | |
exports.width = ""; | |
} | |
if (typeof dim[1] === "number" && !isNaN(parseInt(item.getConfig().height))) { | |
exports.height = dim[1] + "px"; | |
} else if (!isNaN(parseInt(item.getConfig().height))) { | |
exports.height = dim[1]; | |
} else { | |
exports.height = ""; | |
} | |
} | |
exports.large = item.getConfig().large; | |
exports.align = item.getConfig().align; | |
exports.scrollToPlayer = item.getConfig().scrollToPlayer; | |
exports.scrollToPlayerButton = item.getConfig().scrollToPlayerButton; | |
exports.customName = (typeof item.getConfig().customName === "undefined" ? "" : item.getConfig().customName); | |
exports.aspectRatioLocked = (typeof item.getConfig().aspectRatioLocked === "undefined" ? false : item.getConfig().aspectRatioLocked); | |
return exports; | |
} | |
function createEditor() { | |
function hasUnsavedChanges() { | |
if (state === 0) return false; | |
if (state === 2) return true; | |
if (original.width !== __getWidth()) return true; | |
if (original.height !== __getHeight()) return true; | |
if (original.large !== largeInput.isSelected()) return true; | |
//if (original.align !== alignInput.isSelected()) return true; | |
if (original.scrollToPlayer !== scrollToPlayerInput.isSelected()) return true; | |
if (original.scrollToPlayerButton !== scrollToPlayerButtonInput.isSelected()) return true; | |
if (original.customName !== customNameInput.value) return true; | |
if (original.aspectRatioLocked !== ratioLocked) return true; | |
return false; | |
} | |
var __getWidth = function(){ | |
if (isNaN(parseInt(widthInput.value))) { | |
return widthUnit.getValue(); | |
} else { | |
return parseInt(widthInput.value) + widthUnit.getValue(); | |
} | |
}; | |
var __getHeight = function(){ | |
if (isNaN(parseInt(heightInput.value))) { | |
return heightUnit.getValue(); | |
} else { | |
return parseInt(heightInput.value) + heightUnit.getValue(); | |
} | |
}; | |
var __getAspectRatio = function(){ | |
if (isNaN(parseInt(widthInput.value)) || isNaN(parseInt(heightInput.value)) || widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
return parseInt(widthInput.value)/parseInt(heightInput.value); | |
}; | |
var __updateAspectRatio = function(){ | |
aspectRatio = __getAspectRatio(); | |
}; | |
var __setAspectRatioLocked = function(locked){ | |
ratioLocked = locked; | |
if (ratioLocked) { | |
ytcenter.utils.addClass(ratioIcon, "ytcenter-resize-chain"); | |
ytcenter.utils.removeClass(ratioIcon, "ytcenter-resize-unchain"); | |
aspectRatio = __getAspectRatio(); | |
} else { | |
ytcenter.utils.removeClass(ratioIcon, "ytcenter-resize-chain"); | |
ytcenter.utils.addClass(ratioIcon, "ytcenter-resize-unchain"); | |
aspectRatio = undefined; | |
} | |
}; | |
var __setAspectVisibility = function(visible){ | |
if (visible) { | |
ytcenter.utils.removeClass(linkBorder, "force-hid"); | |
ytcenter.utils.removeClass(ratioIcon, "force-hid"); | |
} else { | |
ytcenter.utils.addClass(linkBorder, "force-hid"); | |
ytcenter.utils.addClass(ratioIcon, "force-hid"); | |
} | |
}; | |
var saveListener, cancelListener, deleteListener, newSessionCallback; | |
var original = {}; | |
var state = 0; | |
var ratioLocked = false; | |
var aspectRatio; | |
var wrp = document.createElement("div"); | |
wrp.style.visibility = "hidden"; | |
// Editor Panel | |
var customNameWrapper = document.createElement("div"); | |
customNameWrapper.className = "ytcenter-panel-label"; | |
var customNameLabel = document.createElement("label"); | |
customNameLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_CUSTOMNAME"); | |
ytcenter.language.addLocaleElement(customNameLabel, "EMBED_RESIZEITEMLIST_CUSTOMNAME", "@textContent"); | |
customNameWrapper.appendChild(customNameLabel); | |
var customNameInput = ytcenter.gui.createYouTubeTextInput(); | |
customNameInput.style.width = "210px"; | |
customNameWrapper.appendChild(customNameInput); | |
var dimensionWrapper = document.createElement("div"); | |
var sizeWrapper = document.createElement("div"); | |
sizeWrapper.style.display = "inline-block"; | |
var widthWrapper = document.createElement("div"); | |
widthWrapper.className = "ytcenter-panel-label"; | |
var widthLabel = document.createElement("label"); | |
widthLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_WIDTH"); | |
ytcenter.language.addLocaleElement(widthLabel, "EMBED_RESIZEITEMLIST_WIDTH", "@textContent"); | |
widthWrapper.appendChild(widthLabel); | |
var widthInput = ytcenter.gui.createYouTubeTextInput(); | |
widthInput.style.width = "105px"; | |
widthWrapper.appendChild(widthInput); | |
ytcenter.utils.addEventListener(widthInput, "change", function(){ | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
aspectRatio = __getAspectRatio(); | |
}); | |
ytcenter.utils.addEventListener(widthInput, "input", function(){ | |
if (isNaN(parseInt(widthInput.value))) widthInput.value = ""; | |
else widthInput.value = parseInt(widthInput.value); | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
if (typeof aspectRatio === "undefined" || !ratioLocked) return; | |
if (isNaN(parseInt(widthInput.value))) { | |
heightInput.value = ""; | |
} else if (aspectRatio !== 0) { | |
heightInput.value = Math.round(parseInt(widthInput.value)/aspectRatio); | |
} | |
}); | |
var widthUnit = ytcenter.modules.select({args: {list: [ | |
{label: "EMBED_RESIZEITEMLIST_PIXEL", value: "px"}, | |
{label: "EMBED_RESIZEITEMLIST_PERCENT", value: "%"} | |
]}}); | |
widthUnit.bind(function(){ | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") { | |
__setAspectVisibility(false); | |
return; | |
} | |
__setAspectVisibility(true); | |
aspectRatio = __getAspectRatio(); | |
}); | |
widthWrapper.appendChild(widthUnit.element); | |
sizeWrapper.appendChild(widthWrapper); | |
var heightWrapper = document.createElement("div"); | |
heightWrapper.className = "ytcenter-panel-label"; | |
var heightLabel = document.createElement("label"); | |
heightLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_HEIGHT"); | |
ytcenter.language.addLocaleElement(heightLabel, "EMBED_RESIZEITEMLIST_HEIGHT", "@textContent"); | |
heightWrapper.appendChild(heightLabel); | |
var heightInput = ytcenter.gui.createYouTubeTextInput(); | |
heightInput.style.width = "105px"; | |
heightWrapper.appendChild(heightInput); | |
ytcenter.utils.addEventListener(heightInput, "change", function(){ | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
aspectRatio = __getAspectRatio(); | |
}); | |
ytcenter.utils.addEventListener(heightInput, "input", function(){ | |
if (isNaN(parseInt(heightInput.value))) heightInput.value = ""; | |
else heightInput.value = parseInt(heightInput.value); | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
if (typeof aspectRatio === "undefined" || !ratioLocked) return; | |
if (isNaN(parseInt(heightInput.value))) { | |
widthInput.value = ""; | |
} else if (aspectRatio !== 0) { | |
widthInput.value = Math.round(parseInt(heightInput.value)*aspectRatio); | |
} | |
}); | |
var heightUnit = ytcenter.modules.select({args: {list: [ | |
{label: "EMBED_RESIZEITEMLIST_PIXEL", value: "px"}, | |
{label: "EMBED_RESIZEITEMLIST_PERCENT", value: "%"} | |
]}}); | |
heightUnit.bind(function(){ | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") { | |
__setAspectVisibility(false); | |
return; | |
} | |
__setAspectVisibility(true); | |
aspectRatio = __getAspectRatio(); | |
}); | |
heightWrapper.appendChild(heightUnit.element); | |
sizeWrapper.appendChild(heightWrapper); | |
dimensionWrapper.appendChild(sizeWrapper); | |
var linkBorder = document.createElement("div"); | |
linkBorder.className = "ytcenter-resize-aspect-bind"; | |
dimensionWrapper.appendChild(linkBorder); | |
var ratioIcon = document.createElement("div"); | |
ratioIcon.className = "ytcenter-resize-unchain ytcenter-resize-ratio"; | |
ratioIcon.style.display = "inline-block"; | |
ratioIcon.style.marginBottom = "13px"; | |
ratioIcon.style.marginLeft = "-11px"; | |
ratioIcon.style.width = "20px"; | |
ytcenter.utils.addEventListener(ratioIcon, "click", function(e){ | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") return; | |
if (ratioLocked) { | |
__setAspectRatioLocked(false); | |
} else { | |
__setAspectRatioLocked(true); | |
} | |
if (e && e.preventDefault) { | |
e.preventDefault(); | |
} else { | |
window.event.returnValue = false; | |
} | |
return false; | |
}); | |
dimensionWrapper.appendChild(ratioIcon); | |
var largeWrapper = document.createElement("div"); | |
largeWrapper.className = "ytcenter-panel-label"; | |
var largeLabel = document.createElement("label"); | |
largeLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_LARGE"); | |
ytcenter.language.addLocaleElement(largeLabel, "EMBED_RESIZEITEMLIST_LARGE", "@textContent"); | |
largeWrapper.appendChild(largeLabel); | |
var largeInput = ytcenter.modules.checkbox(); | |
largeInput.element.style.background = "#fff"; | |
largeInput.fixHeight(); | |
largeWrapper.appendChild(largeInput.element); | |
/*var alignWrapper = document.createElement("div"); | |
alignWrapper.className = "ytcenter-panel-label"; | |
var alignLabel = document.createElement("label"); | |
alignLabel.textContent = "Align"; | |
alignLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_ALIGN"); | |
ytcenter.language.addLocaleElement(alignLabel, "EMBED_RESIZEITEMLIST_ALIGN", "@textContent"); | |
alignWrapper.appendChild(alignLabel); | |
var alignInput = ytcenter.modules.checkbox(); | |
alignInput.element.style.background = "#fff"; | |
alignInput.fixHeight(); | |
alignWrapper.appendChild(alignInput.element);*/ | |
var scrollToPlayerWrapper = document.createElement("div"); | |
scrollToPlayerWrapper.className = "ytcenter-panel-label"; | |
var scrollToPlayerLabel = document.createElement("label"); | |
scrollToPlayerLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_SCROLLTOPLAYER"); | |
ytcenter.language.addLocaleElement(scrollToPlayerLabel, "EMBED_RESIZEITEMLIST_SCROLLTOPLAYER", "@textContent"); | |
scrollToPlayerWrapper.appendChild(scrollToPlayerLabel); | |
var scrollToPlayerInput = ytcenter.modules.checkbox(); | |
scrollToPlayerInput.element.style.background = "#fff"; | |
scrollToPlayerInput.fixHeight(); | |
scrollToPlayerWrapper.appendChild(scrollToPlayerInput.element); | |
var scrollToPlayerButtonWrapper = document.createElement("div"); | |
scrollToPlayerButtonWrapper.className = "ytcenter-panel-label"; | |
var scrollToPlayerButtonLabel = document.createElement("label"); | |
scrollToPlayerButtonLabel.textContent = ytcenter.language.getLocale("EMBED_RESIZEITEMLIST_SCROLLTOPLAYERBUTTON"); | |
ytcenter.language.addLocaleElement(scrollToPlayerButtonLabel, "EMBED_RESIZEITEMLIST_SCROLLTOPLAYERBUTTON", "@textContent"); | |
scrollToPlayerButtonWrapper.appendChild(scrollToPlayerButtonLabel); | |
var scrollToPlayerButtonInput = ytcenter.modules.checkbox(); | |
scrollToPlayerButtonInput.element.style.background = "#fff"; | |
scrollToPlayerButtonInput.fixHeight(); | |
scrollToPlayerButtonWrapper.appendChild(scrollToPlayerButtonInput.element); | |
var optionsWrapper = document.createElement("div"); | |
optionsWrapper.className = "clearfix resize-options"; | |
var saveBtn = ytcenter.gui.createYouTubePrimaryButton("", [ytcenter.gui.createYouTubeButtonTextLabel("SETTINGS_PLAYERSIZE_SAVE")]); | |
saveBtn.className += " resize-options-right"; | |
ytcenter.utils.addEventListener(saveBtn, "click", function(){ | |
state = 0; | |
wrp.style.visibility = "hidden"; | |
if (typeof saveListener !== "undefined") saveListener(); | |
ytcenter.events.performEvent("ui-refresh"); | |
}); | |
var cancelBtn = ytcenter.gui.createYouTubeDefaultButton("", [ytcenter.gui.createYouTubeButtonTextLabel("SETTINGS_PLAYERSIZE_CANCEL")]); | |
cancelBtn.className += " resize-options-right"; | |
ytcenter.utils.addEventListener(cancelBtn, "click", function(){ | |
if (hasUnsavedChanges()) { | |
ytcenter.confirmBox("EMBED_RESIZEITEMLIST_CONFIRM_TITLE", "EMBED_RESIZEITEMLIST_UNSAVED_CONFIRM_MESSAGE", function(accepted){ | |
if (accepted) { | |
state = 0; | |
wrp.style.visibility = "hidden"; | |
if (typeof cancelListener !== "undefined") cancelListener(); | |
ytcenter.events.performEvent("ui-refresh"); | |
} | |
}); | |
} else { | |
state = 0; | |
wrp.style.visibility = "hidden"; | |
if (typeof cancelListener !== "undefined") cancelListener(); | |
ytcenter.events.performEvent("ui-refresh"); | |
} | |
}); | |
var deleteBtn = ytcenter.gui.createYouTubeDefaultButton("", [ytcenter.gui.createYouTubeButtonTextLabel("SETTINGS_PLAYERSIZE_DELETE")]); | |
deleteBtn.className += " resize-options-left"; | |
ytcenter.utils.addEventListener(deleteBtn, "click", function(){ | |
ytcenter.confirmBox("EMBED_RESIZEITEMLIST_DELETE_CONFIRM_TITLE", "EMBED_RESIZEITEMLIST_DELETE_CONFIRM_MESSAGE", function(del){ | |
if (del) { | |
state = 0; | |
wrp.style.visibility = "hidden"; | |
if (typeof deleteListener !== "undefined") deleteListener(); | |
ytcenter.events.performEvent("ui-refresh"); | |
} | |
}, "EMBED_RESIZEITEMLIST_CONFIRM_DELETE"); | |
}); | |
optionsWrapper.appendChild(deleteBtn); | |
optionsWrapper.appendChild(saveBtn); | |
optionsWrapper.appendChild(cancelBtn); | |
wrp.appendChild(customNameWrapper); | |
wrp.appendChild(dimensionWrapper); | |
wrp.appendChild(largeWrapper); | |
//wrp.appendChild(alignWrapper); | |
wrp.appendChild(scrollToPlayerWrapper); | |
wrp.appendChild(scrollToPlayerButtonWrapper); | |
wrp.appendChild(optionsWrapper); | |
editWrapper.appendChild(wrp); | |
return { | |
destroy: function(){ | |
editWrapper.removeChild(wrp); | |
}, | |
hasUnsavedChanges: hasUnsavedChanges, | |
setState: function(s){ | |
state = s; | |
}, | |
setDeleteButtonVisibility: function(visible) { | |
if (visible) { | |
deleteBtn.style.visibility = ""; | |
} else { | |
deleteBtn.style.visibility = "hidden"; | |
} | |
}, | |
setSaveListener: function(callback){ | |
saveListener = callback; | |
}, | |
setCancelListener: function(callback){ | |
cancelListener = callback; | |
}, | |
setDeleteListener: function(callback){ | |
deleteListener = callback; | |
}, | |
updateAspectRatio: function(){ | |
__updateAspectRatio(); | |
}, | |
getAspectRatio: function(){ | |
return aspectRatio; | |
}, | |
setAspectRatioLocked: function(locked){ | |
__setAspectRatioLocked(locked); | |
original.aspectRatioLocked = ratioLocked; | |
}, | |
isAspectRatioLocked: function(){ | |
return ratioLocked; | |
}, | |
setWidth: function(width){ | |
state = 1; | |
if (width === "") { // Default | |
widthInput.value = ""; | |
widthUnit.setSelected("px"); | |
width = "px"; | |
} else { | |
var _val = parseInt(width); | |
if (isNaN(_val)) { | |
widthInput.value = ""; | |
} else { | |
widthInput.value = _val; | |
} | |
widthUnit.setSelected((width.indexOf("%") !== -1 ? "%" : "px")); | |
} | |
original.width = __getWidth(); | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") { | |
__setAspectVisibility(false); | |
} else { | |
__setAspectVisibility(true); | |
} | |
}, | |
getWidth: __getWidth, | |
setHeight: function(height){ | |
state = 1; | |
if (height === "") { // Default | |
heightInput.value = ""; | |
heightUnit.setSelected("px"); | |
height = "px"; | |
} else { | |
var _val = parseInt(height); | |
if (isNaN(_val)) { | |
heightInput.value = ""; | |
} else { | |
heightInput.value = _val; | |
} | |
heightUnit.setSelected((height.indexOf("%") !== -1 ? "%" : "px")); | |
} | |
original.height = __getHeight(); | |
if (widthUnit.getValue() !== "px" || heightUnit.getValue() !== "px") { | |
__setAspectVisibility(false); | |
} else { | |
__setAspectVisibility(true); | |
} | |
}, | |
getHeight: __getHeight, | |
setLarge: function(large){ | |
state = 1; | |
largeInput.update(large); | |
original.large = largeInput.isSelected(); | |
}, | |
getLarge: function(){ | |
return largeInput.isSelected(); | |
}, | |
setAlign: function(align){ | |
state = 1; | |
/*alignInput.update(align); | |
original.align = alignInput.isSelected();*/ | |
}, | |
getAlign: function(){ | |
//return alignInput.isSelected(); | |
return false; | |
}, | |
setScrollToPlayer: function(scrollToPlayer){ | |
state = 1; | |
scrollToPlayerInput.update(scrollToPlayer); | |
original.scrollToPlayer = scrollToPlayerInput.isSelected(); | |
}, | |
getScrollToPlayer: function(){ | |
return scrollToPlayerInput.isSelected(); | |
}, | |
setScrollToPlayerButton: function(scrollToPlayerButton){ | |
state = 1; | |
scrollToPlayerButtonInput.update(scrollToPlayerButton); | |
original.scrollToPlayerButton = scrollToPlayerButtonInput.isSelected(); | |
}, | |
getScrollToPlayerButton: function(){ | |
return scrollToPlayerButtonInput.isSelected(); | |
}, | |
setCustomName: function(customName){ | |
if (typeof customName !== "string") customName = ""; | |
state = 1; | |
customNameInput.value = customName; | |
original.customName = customName; | |
}, | |
getCustomName: function(){ | |
return customNameInput.value; | |
}, | |
setVisibility: function(visible) { | |
if (visible) { | |
wrp.style.visibility = ""; | |
} else { | |
wrp.style.visibility = "hidden"; | |
} | |
}, | |
newSession: function(){ | |
if (typeof newSessionCallback !== "undefined") newSessionCallback(); | |
}, | |
setSessionListener: function(callback){ | |
newSessionCallback = callback; | |
}, | |
focusCustomNameField: function(){ | |
customNameInput.focus(); | |
}, | |
focusWidthField: function(){ | |
widthInput.focus(); | |
}, | |
focusHeightField: function(){ | |
heightInput.focus(); | |
} | |
}; | |
} | |
function getItemTitle(item) { | |
var dim = ytcenter.utils.calculateDimensions(item.getConfig().width, item.getConfig().height); | |
if (typeof item.getConfig().customName !== "undefined" && item.getConfig().customName !== "") { | |
return item.getConfig().customName; | |
} else if (isNaN(parseInt(item.getConfig().width)) && isNaN(parseInt(item.getConfig().height))) { | |
return (item.getConfig().large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")); | |
subtext.textContent = (item.getConfig().align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER")); | |
} else { | |
return dim[0] + "×" + dim[1]; | |
subtext.textContent = (item.getConfig().large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + (item.getConfig().align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER")); | |
} | |
} | |
function getItemSubText(item) { | |
if (isNaN(parseInt(item.getConfig().width)) && isNaN(parseInt(item.getConfig().height))) { | |
return ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.getConfig().scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} else { | |
return (item.getConfig().large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")) + " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER") + (item.getConfig().scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); | |
} | |
} | |
function updateListHeight() { | |
var _h = editWrapper.clientHeight || editWrapper.scrollHeight; | |
if (_h > 0) listWrapper.style.height = _h + "px"; | |
} | |
function selectSizeItem(id) { | |
var bypassConfirm = false; | |
if (typeof editor === "undefined") { | |
bypassConfirm = true; | |
editor = createEditor(); | |
} | |
var overrideData = function(){ | |
editor.newSession(); | |
var newItem = false; | |
var newItemSaved = false; | |
var newItemCancled = false; | |
var item; | |
if (typeof id === "undefined") { | |
newItem = true; | |
item = createEmptyItem(); | |
items.push(item); | |
listOl.appendChild(item.getItemElement()); | |
listOl.scrollTop = listOl.scrollHeight - listOl.clientHeight; | |
} else { | |
item = getItemById(id); | |
} | |
markItem(item.getId()); | |
var inf = getItemInfo(item); | |
editor.setCustomName(inf.customName); | |
editor.setWidth(inf.width); | |
editor.setHeight(inf.height); | |
editor.setAspectRatioLocked(inf.aspectRatioLocked); | |
editor.setLarge(inf.large); | |
editor.setAlign(inf.align); | |
editor.setScrollToPlayer(inf.scrollToPlayer); | |
editor.setScrollToPlayerButton(inf.scrollToPlayerButton); | |
editor.updateAspectRatio(); | |
editor.setSessionListener(function(){ | |
if (!newItem || newItemSaved || newItemCancled) return; | |
var sI; | |
for (var i = 0; i < items.length; i++) { | |
sI = i; | |
if (items[i].getId() === item.getId()) break; | |
} | |
items.splice(sI, 1); | |
if (typeof item.getItemElement().parentNode !== "undefined") item.getItemElement().parentNode.removeChild(item.getItemElement()); | |
if (typeof saveCallback !== "undefined") saveCallback(getSaveArray()); | |
}); | |
editor.setSaveListener(function(){ | |
newItemSaved = true; | |
item.setConfig({ | |
customName: editor.getCustomName(), | |
width: editor.getWidth(), | |
height: editor.getHeight(), | |
large: editor.getLarge(), | |
align: editor.getAlign(), | |
scrollToPlayer: editor.getScrollToPlayer(), | |
scrollToPlayerButton: editor.getScrollToPlayerButton(), | |
aspectRatioLocked: editor.isAspectRatioLocked() | |
}); | |
item.updateItemElement(); | |
unMarkAllItems(); | |
if (typeof saveCallback !== "undefined") saveCallback(getSaveArray()); | |
}); | |
editor.setCancelListener(function(){ | |
if (newItem) { | |
newItemCancled = true; | |
var sI; | |
for (var i = 0; i < items.length; i++) { | |
sI = i; | |
if (items[i].getId() === item.getId()) break; | |
} | |
items.splice(sI, 1); | |
if (item.getItemElement().parentNode) item.getItemElement().parentNode.removeChild(item.getItemElement()); | |
if (typeof saveCallback !== "undefined") saveCallback(getSaveArray()); | |
} | |
unMarkAllItems(); | |
}); | |
editor.setDeleteListener(function(){ | |
try { | |
if (newItem) return; | |
if (ytcenter.player.isSelectedPlayerSizeById(item.getId())) { | |
if (ytcenter.settings["resize-playersizes"][0].id === item.getId()) { | |
if (ytcenter.settings["resize-playersizes"].length > 1) { | |
ytcenter.player.resize(ytcenter.settings["resize-playersizes"][1]); | |
} | |
} else { | |
ytcenter.player.resize(ytcenter.settings["resize-playersizes"][0]); | |
} | |
} | |
unMarkAllItems(); | |
if (typeof item.getItemElement().parentNode !== "undefined") item.getItemElement().parentNode.removeChild(item.getItemElement()); | |
var sI; | |
for (var i = 0; i < items.length; i++) { | |
sI = i; | |
if (items[i].getId() === item.getId()) break; | |
} | |
items.splice(sI, 1); | |
if (typeof saveCallback !== "undefined") saveCallback(getSaveArray()); | |
} catch (e) { | |
con.error(e); | |
} | |
}); | |
editor.setDeleteButtonVisibility(!newItem); | |
editor.setVisibility(true); | |
editor.focusCustomNameField(); | |
if (newItem) editor.setState(2); | |
}; | |
if (editor.hasUnsavedChanges() && !bypassConfirm) { | |
ytcenter.confirmBox("EMBED_RESIZEITEMLIST_CONFIRM_TITLE", "EMBED_RESIZEITEMLIST_UNSAVED_CONFIRM_MESSAGE", function(accepted){ | |
if (accepted) { | |
editor.setState(0); | |
overrideData(); | |
} | |
}); | |
} else { | |
overrideData(); | |
} | |
updateListHeight(); | |
} | |
function getItemById(id) { | |
for (var i = 0; i < items.length; i++) { | |
if (items[i].getId() === id) return items[i]; | |
} | |
} | |
function unMarkAllItems() { | |
for (var i = 0; i < items.length; i++) { | |
items[i].setSelection(false); | |
} | |
} | |
function markItem(id) { | |
unMarkAllItems(); | |
getItemById(id).setSelection(true); | |
} | |
function getSaveArray() { | |
var _s = []; | |
for (var i = 0; i < items.length; i++) { | |
_s.push(items[i].getData()); | |
} | |
return _s; | |
} | |
function getItemByElement(li) { | |
for (var i = 0; i < items.length; i++) { | |
if (items.getItemElement() === li) return items[i]; | |
} | |
} | |
function createEmptyItem() { | |
return wrapItem({ | |
id: ytcenter.utils.assignId("resize_item_list_"), | |
config: { | |
customName: "", | |
width: "", | |
height: "", | |
large: true, | |
align: false, | |
scrollToPlayer: false, | |
scrollToPlayerButton: false, | |
aspectRatioLocked: false | |
} | |
}); | |
} | |
function setItems(_items) { | |
items = []; | |
ytcenter.utils.each(_items, function(i, item){ | |
items.push(wrapItem(item)); | |
}); | |
listOl.innerHTML = ""; | |
ytcenter.utils.each(items, function(i, item){ | |
var a = item.getItemElement(); | |
listOl.appendChild(a); | |
}); | |
} | |
var editor; | |
var saveCallback; | |
var items = []; | |
var lastValue = ytcenter.settings[option.defaultSetting]; | |
var wrapper = document.createElement("div"); | |
wrapper.className = "ytcenter-embed ytcenter-resize-panel"; | |
var headerWrapper = document.createElement("div"); | |
headerWrapper.className = "ytcenter-resize-panel-header"; | |
var addButton = ytcenter.gui.createYouTubeDefaultButton("", [ytcenter.gui.createYouTubeButtonTextLabel("EMBED_RESIZEITEMLIST_ADD_SIZE")]); | |
ytcenter.utils.addClass(addButton, "ytcenter-list-header-btn"); | |
ytcenter.utils.addEventListener(addButton, "click", function(){ | |
selectSizeItem(); | |
}); | |
headerWrapper.appendChild(addButton); | |
var contentWrapper = document.createElement("div"); | |
contentWrapper.className = "ytcenter-resize-panel-content"; | |
var positionerEditWrapper = document.createElement("div"); | |
positionerEditWrapper.className = "ytcenter-resize-panel-right"; | |
var editWrapper = document.createElement("div"); | |
editWrapper.className = "ytcenter-panel"; | |
positionerEditWrapper.appendChild(editWrapper); | |
var listWrapper = document.createElement("div"); | |
listWrapper.className = "ytcenter-resize-panel-list"; | |
var listOl = document.createElement("ol"); | |
listOl.className = "ytcenter-list ytcenter-dragdrop ytcenter-scrollbar ytcenter-scrollbar-hover"; | |
var dd = ytcenter.dragdrop(listOl); | |
dd.addEventListener("onDrop", function(newIndex, oldIndex, item){ | |
var itm = items[oldIndex]; | |
items.splice(oldIndex, 1); | |
items.splice(newIndex, 0, itm); | |
if (saveCallback) saveCallback(getSaveArray()); | |
//ytcenter.events.performEvent("ui-refresh"); | |
}); | |
listWrapper.appendChild(listOl); | |
contentWrapper.appendChild(listWrapper); | |
contentWrapper.appendChild(positionerEditWrapper); | |
wrapper.appendChild(headerWrapper); | |
wrapper.appendChild(contentWrapper); | |
if (option.parent) { | |
option.parent.addEventListener("click", function(){ | |
if (!editor) { | |
editor = createEditor(); | |
} | |
updateListHeight(); | |
}); | |
} | |
setItems(lastValue); | |
return { | |
element: wrapper, // So the element can be appended to an element. | |
bind: function(callback){ | |
saveCallback = function(arg){ | |
if (callback) callback(arg); | |
ytcenter.player.resizeUpdater(); | |
} | |
}, | |
update: function(value){ | |
if (value === lastValue) return; | |
lastValue = value; | |
setItems(value); | |
if (typeof editor !== "undefined") editor.setVisibility(false); | |
} | |
}; | |
}; | |
ytcenter.modules.select = function(option){ | |
function updateList() { | |
select.innerHTML = ""; | |
ytcenter.utils.each(list, function(i, item){ | |
var o = document.createElement("option"); | |
o.setAttribute("value", i); | |
if (typeof item.label !== "undefined") { | |
o.textContent = ytcenter.language.getLocale(item.label); | |
ytcenter.language.addLocaleElement(o, item.label, "@textContent"); | |
} else if (typeof item.text !== "undefined") { | |
o.textContent = item.text; | |
} else { | |
o.textContent = "undefined"; | |
} | |
if (selectedValue === item.value) { | |
o.setAttribute("selected", "selected"); | |
selectedText.textContent = o.textContent; | |
} | |
select.appendChild(o); | |
}); | |
} | |
var list = (option && option.args && option.args.list) || [], | |
selectedValue, saveCallback, | |
wrapper = document.createElement("span"), | |
selectedContentWrapper = document.createElement("span"), | |
selectedArrow = document.createElement("img"), | |
selectedText = document.createElement("span"), | |
select = document.createElement("select"); | |
wrapper.className = "ytcenter-embed yt-uix-form-input-select"; | |
wrapper.style.marginBottom = "2px"; | |
wrapper.style.height = "27px"; | |
selectedContentWrapper.className = "yt-uix-form-input-select-content"; | |
selectedArrow.setAttribute("src", "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"); | |
selectedArrow.className = "yt-uix-form-input-select-arrow"; | |
selectedText.className = "yt-uix-form-input-select-value"; | |
selectedContentWrapper.appendChild(selectedArrow); | |
selectedContentWrapper.appendChild(selectedText); | |
select.className = "yt-uix-form-input-select-element"; | |
select.style.cursor = "pointer"; | |
select.style.height = "27px"; | |
updateList(); | |
ytcenter.utils.addEventListener(select, "change", function(e){ | |
selectedText.textContent = select.options[select.selectedIndex].textContent; | |
if (saveCallback) saveCallback(list[select.selectedIndex].value); | |
}); | |
wrapper.appendChild(selectedContentWrapper); | |
wrapper.appendChild(select); | |
return { | |
element: wrapper, | |
bind: function(callback){ | |
saveCallback = callback; | |
}, | |
setSelected: function(value){ | |
selectedValue = value; | |
for (var i = 0; i < list.length; i++) { | |
if (list[i].value === value) { | |
select.selectedIndex = i; | |
break; | |
} | |
} | |
if (select.options.length > 0) selectedText.textContent = select.options[select.selectedIndex].textContent; | |
}, | |
update: function(value){ | |
selectedValue = value; | |
for (var i = 0; i < list.length; i++) { | |
if (list[i].value === value) { | |
select.selectedIndex = i; | |
break; | |
} | |
} | |
if (select.options.length > 0) selectedText.textContent = select.options[select.selectedIndex].textContent; | |
}, | |
updateList: function(_list){ | |
list = _list; | |
updateList(); | |
}, | |
getValue: function(){ | |
return list[select.selectedIndex].value; | |
} | |
}; | |
}; | |
ytcenter.modules.textarea = function(option){ | |
var elm = document.createElement('textarea'), i, key; | |
elm.className = "yt-uix-form-textarea"; | |
if (option && option.args && option.args.className) { | |
elm.className += " " + option.args.className; | |
} | |
if (option && option.args && option.args.styles) { | |
for (key in option.args.styles) { | |
if (option.args.styles.hasOwnProperty(key)) { | |
elm.style.setProperty(key, option.args.styles[key]); | |
} | |
} | |
} | |
if (option && option.args && option.args.text) { | |
elm.textContent = option.args.text; | |
} | |
if (option && option.args && option.args.attributes) { | |
for (key in option.args.attributes) { | |
if (option.args.attributes.hasOwnProperty(key)) { | |
elm.setAttribute(key, option.args.attributes[key]); | |
} | |
} | |
} | |
if (option && option.args && option.args.listeners) { | |
for (i = 0; i < option.args.listeners.length; i++) { | |
elm.addEventListener(option.args.listeners[i].event, option.args.listeners[i].callback, (option.args.listeners[i].bubble ? option.args.listeners[i].bubble : false)); | |
} | |
} | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){}, | |
setText: function(txt){ | |
elm.textContent = txt; | |
}, | |
selectAll: function(){ | |
elm.focus(); | |
elm.select(); | |
} | |
}; | |
}; | |
ytcenter.modules.textContent = function(option){ | |
var elm = document.createElement("div"); | |
if (option && option.args && option.args.styles) { | |
for (var key in option.args.styles) { | |
if (option.args.styles.hasOwnProperty(key)) { | |
elm.style[key] = option.args.styles[key]; | |
} | |
} | |
} | |
if (option && option.args && option.args.text) { | |
if (option && option.args && option.args.replace) { | |
elm.appendChild(ytcenter.utils.replaceText(option.args.text, option.args.replace)); | |
} else { | |
elm.textContent = option.args.text; | |
} | |
} | |
if (option && option.args && option.args.textlocale) { | |
if (option && option.args && option.args.replace) { | |
elm.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale(option.args.textlocale), option.args.replace)); | |
} else { | |
elm.textContent = ytcenter.language.getLocale(option.args.textlocale); | |
} | |
ytcenter.events.addEvent("language-refresh", function(){ | |
elm.innerHTML = ""; | |
if (option && option.args && option.args.replace) { | |
elm.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale(option.args.textlocale), option.args.replace)); | |
} else { | |
elm.textContent = ytcenter.language.getLocale(option.args.textlocale); | |
} | |
}); | |
} | |
if (option && option.args && option.args.listeners) { | |
for (var i = 0; i < option.args.listeners.length; i++) { | |
elm.addEventListener(option.args.listeners[i].event, option.args.listeners[i].callback, (option.args.listeners[i].bubble ? option.args.listeners[i].bubble : false)); | |
} | |
} | |
if (option && option.args && option.args.styles) { | |
for (var key in option.args.styles) { | |
if (option.args.styles.hasOwnProperty(key)) { | |
elm.style[key] = option.args.styles[key]; | |
} | |
} | |
} | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
ytcenter.modules.textfield = function(option){ | |
function update(text) { | |
input.value = text; | |
} | |
function bind(callback) { | |
ytcenter.utils.addEventListener(input, "change", function(){ | |
callback(input.value); | |
}, false); | |
} | |
var frag = document.createDocumentFragment(), | |
input = document.createElement("input"); | |
input.setAttribute("type", "text"); | |
input.className = "yt-uix-form-input-text"; | |
input.value = option && ytcenter.settings[option.defaultSetting]; | |
if (option && option.style) { | |
for (var key in option.style) { | |
if (option.style.hasOwnProperty(key)) { | |
elm.style[key] = option.style[key]; | |
} | |
} | |
} | |
frag.appendChild(input); | |
return { | |
element: frag, | |
bind: bind, | |
update: update | |
}; | |
}; | |
ytcenter.modules.translators = function(option){ | |
option = typeof option !== "undefined" ? option : false; | |
var elm = document.createElement("div"); | |
var translators = document.createElement("div"), | |
table = document.createElement("table"), | |
thead = document.createElement("thead"), | |
tbody = document.createElement("tbody"), | |
tr, td; | |
table.className = "ytcenter-settings-table"; | |
tr = document.createElement("tr"); | |
td = document.createElement("td"); | |
td.textContent = ytcenter.language.getLocale("TRANSLATOR_LANGUAGE"); | |
ytcenter.language.addLocaleElement(td, "TRANSLATOR_LANGUAGE", "@textContent"); | |
tr.appendChild(td); | |
td = document.createElement("td"); | |
td.textContent = ytcenter.language.getLocale("TRANSLATOR_ENGLISH"); | |
ytcenter.language.addLocaleElement(td, "TRANSLATOR_ENGLISH", "@textContent"); | |
tr.appendChild(td); | |
td = document.createElement("td"); | |
td.textContent = ytcenter.language.getLocale("TRANSLATOR_CONTRIBUTORS"); | |
ytcenter.language.addLocaleElement(td, "TRANSLATOR_CONTRIBUTORS", "@textContent"); | |
tr.appendChild(td); | |
thead.appendChild(tr); | |
table.appendChild(thead); | |
table.appendChild(tbody); | |
ytcenter.utils.each(option.args.translators, function(key, value){ | |
if (value.length > 0) { | |
tr = document.createElement("tr"); | |
td = document.createElement("td"); | |
td.textContent = ytcenter.language.getLocale("LANGUAGE", key); | |
tr.appendChild(td); | |
td = document.createElement("td"); | |
td.textContent = ytcenter.language.getLocale("LANGUAGE_ENGLISH", key); | |
tr.appendChild(td); | |
td = document.createElement("td"); | |
for (var i = 0; i < value.length; i++) { | |
if (i > 0) td.appendChild(document.createTextNode(" & ")); | |
var el; | |
if (value[i].url) { | |
el = document.createElement("a"); | |
el.href = value[i].url; | |
el.textContent = value[i].name; | |
el.setAttribute("target", "_blank"); | |
} else { | |
el = document.createTextNode(value[i].name); | |
} | |
td.appendChild(el); | |
} | |
tr.appendChild(td); | |
tbody.appendChild(tr); | |
} | |
}); | |
translators.appendChild(table); | |
elm.appendChild(translators); | |
return { | |
element: elm, | |
bind: function(){}, | |
update: function(){} | |
}; | |
}; | |
// @support | |
ytcenter.supported = {}; | |
ytcenter.supported.localStorage = (function(){ | |
var mod = "ytc.supported"; | |
try { | |
uw.localStorage.setItem(mod, mod); | |
uw.localStorage.removeItem(mod); | |
return true; | |
} catch (e) { | |
return false; | |
} | |
})(); | |
ytcenter.supported.CustomEvent = (function(){ | |
var mod = "support.test"; | |
try { | |
var e = document.createEvent('CustomEvent'); | |
if (e && typeof e.initCustomEvent === "function") { | |
e.initCustomEvent(mod, true, true, { mod: mod }); | |
return true; | |
} | |
return false; | |
} catch (e) { | |
return false; | |
} | |
})(); | |
// @unsafeCall | |
ytcenter.unsafeCall = (function(){ | |
function storeFunctions(obj) { | |
if (Object.prototype.toString.call(obj) === "[object Array]") { | |
var i; | |
for (i = 0; i < obj.length; i++) { | |
obj[i] = storeFunctions(obj[i]); | |
} | |
} else if (typeof obj === "function") { | |
return comm.push(obj) - 1; | |
} else if (obj === Object(obj)) { | |
var key; | |
for (key in obj) { | |
if (obj.hasOwnProperty(key)) { | |
obj[key] = storeFunctions(obj[key]); | |
} | |
} | |
} | |
return obj; | |
} | |
function call(method, args, callback) { | |
var id = null; | |
if (callback !== null) { | |
id = comm.push(callback) - 1; | |
} | |
var detail = { id: id, method: method, arguments: storeFunctions(args) }; | |
if (ytcenter.supported.CustomEvent) { | |
callEvent(detail); | |
} else { | |
callMessage(detail); | |
} | |
} | |
function callMessage(detail) { | |
detail.level = "unsafe"; | |
postMessage(JSON.stringify(detail)); | |
} | |
function callEvent(detail) { | |
var event = document.createEvent("CustomEvent"); | |
event.initCustomEvent("ytc-content-call", true, true, JSON.stringify(detail)); | |
document.documentElement.dispatchEvent(event); | |
} | |
function resp(e) { | |
if (!e || !e.data) return; // Checking if data is present | |
if (typeof e.data !== "string") return; // Checking if the object is a string. | |
if (!e.data.indexOf || e.data.indexOf("{") !== 0) return; | |
var data = JSON.parse(e.data); | |
if (data.level === "unsafe") return; | |
if (typeof comm[data.id] === "function") { | |
comm[data.id].apply(null, data.arguments); | |
} | |
} | |
function eventResponse(e) { | |
var detail = e.detail; | |
if (typeof detail !== "object") detail = JSON.parse(detail); | |
if (typeof comm[detail.id] === "function") { | |
comm[detail.id].apply(null, detail.arguments); | |
} | |
if (e && typeof e.stopPropagation === "function") e.stopPropagation(); | |
} | |
function postMessage(data) { | |
window.postMessage(data, "*"); | |
} | |
function initListeners() { | |
if (ytcenter.supported.CustomEvent) { | |
window.addEventListener("ytc-page-call", eventResponse, false); | |
} else { | |
window.addEventListener("message", resp, false); | |
} | |
} | |
var comm = []; | |
initListeners(); | |
return call; | |
})(); | |
/* The util function "throttle" and "once" has been taken from Underscore. | |
* ************************** | |
* http://underscorejs.org | |
* (c) 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Underscore may be freely distributed under the MIT license. | |
*/ | |
ytcenter.utils.throttle = function(func, delay, options){ | |
function timeout() { | |
previous = options.leading === false ? 0 : new Date; | |
timer = null; | |
result = func.apply(context, args); | |
} | |
var context, args, result, timer = null, previous = 0; | |
options = options || {}; | |
return function(){ | |
var now = new Date, dt; | |
context = this; | |
args = arguments; | |
if (!previous && options.leading === false) previous = now; | |
dt = delay - (now - previous); | |
if (dt <= 0) { | |
uw.clearTimeout(timer); | |
timer = null; | |
previous = now; | |
result = func.apply(context, args); | |
} else if (!timer && options.trailing !== false) { | |
timer = uw.setTimeout(timeout, dt); | |
} | |
return result; | |
}; | |
}; | |
// @tabEvents | |
ytcenter.tabEvents = (function(){ | |
/* Fire an event to the other tabs for Firefox */ | |
function fireEventFirefox() { | |
ytcenter.unsafeCall("firefox_windowLinkerFireRegisteredEvent", Array.prototype.slice.call(arguments, 0)); | |
} | |
function fireEventLocalStorage() { | |
// Create a guid if a guid hasn't been created. | |
if (!guid) guid = ytcenter.utils.guid(); | |
var locked = parseInt(uw.localStorage.getItem(STORAGE_LOCK) || 0, 10); | |
var now = ytcenter.utils.now(); | |
var args = Array.prototype.slice.call(arguments, 0); | |
if (locked && now - locked < STORAGE_TIMEOUT) { | |
uw.setTimeout(ytcenter.utils.funcBind.apply(ytcenter.utils, [null, fireEventLocalStorage].concat(args)), STORAGE_WAIT); | |
} else { | |
hasLock = true; | |
uw.localStorage.setItem(STORAGE_LOCK, now); | |
uw.localStorage.setItem(STORAGE_KEY, JSON.stringify({ | |
origin: guid, | |
args: args | |
})); | |
cleanThrottle(); // wait x milliseconds until cleaning items | |
} | |
} | |
/* The standard event handler, which every handler will call at the end. */ | |
function eventFired(event) { | |
if (!listeners[event]) return; | |
var args = Array.prototype.slice.call(arguments, 1); | |
for (var i = 0, len = listeners[event].length; i < len; i++) { | |
listeners[event][i].apply(null, args); | |
} | |
} | |
/* Event handler for the localStorage */ | |
function eventFiredStorage(e) { | |
e = e || uw.event; | |
if (e.key === STORAGE_KEY) { | |
var data = JSON.parse(e.newValue || "{}"); | |
if (data.origin !== guid) { | |
eventFired.apply(null, data.args); | |
} | |
} | |
} | |
function clean() { | |
if (hasLock) { | |
hasLock = false; | |
uw.localStorage.removeItem(STORAGE_LOCK); | |
uw.localStorage.removeItem(STORAGE_KEY); | |
} | |
} | |
/* Add an event listener to get information from other tabs */ | |
function addEventListener(event, callback) { | |
if (!listeners[event]) listeners[event] = []; | |
listeners[event].push(callback); | |
} | |
/* Remove the added event listener */ | |
function removeEventListener(event, callback) { | |
if (!listeners[event]) return; | |
for (var i = 0, len = listeners[event].length; i < len; i++) { | |
listeners[event].splice(i, 1); | |
break; | |
} | |
} | |
/* Firefox replacement */ | |
function addWindowListener(callback) { | |
ytcenter.unsafeCall("firefox_addWindowListener", [], callback); | |
} | |
/* Init the event handlers */ | |
function init() { | |
if (firefox) { | |
addWindowListener(eventFired); /* Firefox addon function */ | |
} else if (ytcenter.supported.localStorage) { | |
if (typeof uw.addEventListener === "function") { | |
uw.addEventListener("storage", eventFiredStorage, false); | |
} else if (typeof uw.attachEvent === "function") { | |
uw.attachEvent("onstorage", eventFiredStorage, false); | |
} | |
} | |
} | |
function getExportsFirefox() { | |
return { | |
addEventListener: addEventListener, | |
removeEventListener: removeEventListener, | |
fireEvent: fireEventFirefox | |
}; | |
} | |
function getExportsLocalStorage() { | |
return { | |
addEventListener: addEventListener, | |
removeEventListener: removeEventListener, | |
fireEvent: fireEventLocalStorage | |
}; | |
} | |
function getExportsPlaceholder() { | |
function empty() { } | |
return { | |
addEventListener: empty, | |
removeEventListener: empty, | |
fireEvent: empty | |
}; | |
} | |
function getExports() { | |
if (firefox) { | |
return getExportsFirefox(); | |
} else if (ytcenter.supported.localStorage) { | |
return getExportsLocalStorage(); | |
} else { | |
return getExportsPlaceholder(); | |
} | |
} | |
var listeners = {}; | |
var guid = null; | |
var firefox = identifier === 6; | |
var hasLock = false; | |
var STORAGE_KEY = "CMS-YTC"; | |
var STORAGE_LOCK = "CMS-YTC-LOCK"; | |
var STORAGE_EXPIRED = 3600000; | |
var STORAGE_WAIT = 50; | |
var STORAGE_TIMEOUT = 1000; | |
var STORAGE_CLEAN = 1000; | |
var cleanThrottle = ytcenter.utils.throttle(clean, STORAGE_CLEAN); | |
init(); | |
return getExports(); | |
})(); | |
ytcenter.channelPlaylistLinks = (function(){ | |
function update() { | |
var page = ytcenter.getPage(); | |
if (page === "channel") { | |
if (!ytcenter.settings.channelUploadedVideosPlaylist) { | |
var elements = document.getElementsByTagName("a"); | |
for (var i = 0, len = elements.length; i < len; i++) { | |
var el = elements[i]; | |
if (el && typeof el.getAttribute === "function") { | |
var href = el.getAttribute("href"); | |
if (href && typeof href.match === "function" && href.match(/^\/watch\?v=[a-zA-Z0-9_\-]+&list=/g) && (ytcenter.utils.hasClass(el, "ux-thumb-wrap") || ytcenter.utils.hasClass(el, "yt-uix-tile-link"))) { | |
el.setAttribute("href", /^(\/watch\?v=[a-zA-Z0-9_\-]+)&list=/g.exec(href)[1]); | |
el.setAttribute("data-ytc-href", href); | |
} | |
} | |
} | |
} else { | |
var elements = document.getElementsByTagName("a"); | |
for (var i = 0, len = elements.length; i < len; i++) { | |
var el = elements[i]; | |
if (el && typeof el.getAttribute === "function") { | |
var href = el.getAttribute("data-ytc-href"); | |
if (href) { | |
el.setAttribute("href", href); | |
el.removeAttribute("data-ytc-href"); | |
} | |
} | |
} | |
} | |
} | |
} | |
return { | |
update: update | |
}; | |
})(); | |
ytcenter.html5Fix = (function(){ | |
/* Begin Yonezpt workaround for issue #1083 (#1125) */ | |
function detour(b, c) { | |
return function(){ | |
// we will call the original sizes, store them in the "changed" variable and | |
// check wether it has the width and height properties. If it does then we | |
// will change them, if not then we relay whatever other arguments the | |
// unknown function calls require | |
var changed = b.apply(this, arguments); | |
if (changed.width && changed.height && ytcenter.getPage() === "watch") { | |
// the variable "c" is just a way to distinguish between sizes for the video canvas | |
// and sizes for the progressbar, and its components | |
// TODO Try using clientWidth or the likes instead of bounding client rect as i.e. clientWidth is better supported. | |
var movie_player = document.getElementById("movie_player"); | |
var html5_container = document.getElementsByClassName("html5-video-container"); | |
var rect = null; | |
if (c && movie_player) { | |
rect = movie_player.getBoundingClientRect(); | |
} else if (html5_container && html5_container.length > 0 && html5_container[0]) { | |
rect = html5_container[0].getBoundingClientRect(); | |
} | |
changed.width = rect.width; | |
changed.height = rect.height; | |
} | |
return changed; | |
}; | |
} | |
function patchDetour() { | |
var i, j; | |
try { | |
// first of all we will find our main pointer that targets the two functions we want | |
// to intercept and for that we will iterate through all the keys in the player instance | |
// object (which is acquired by attaching a variable to the Application.create function | |
// which you -YePpHa- already know), find our target functions and "patch" them | |
// accordingly | |
for (i in playerInstance) { | |
// first filtering step is to only work with keys that are objects, aren't null objects | |
// and contain the .element key - there is only one object that contains it which | |
// is the one that we want | |
if (typeof playerInstance[i] === 'object' && playerInstance[i] && playerInstance[i].element) { | |
con.log('Pointer: ' + i); | |
// now that we have our main pointer we will iterate through all its keys | |
// to find our target functions | |
for (j in playerInstance[i]) { | |
// here we check for the main properties of the functions that we want to | |
// find and for that we will check for certain details inside the functions | |
// that we are currently iterating. never use properties that can be changed | |
// when the script is minified -such as named functions- instead use | |
// native javascript nomenclature which is less likely to change. | |
// in this case both our functions contain the return"detailpage" text | |
// so we will be looking for that line in each function. | |
// we also only want to look for functions, the rest will only be a waste of time | |
if (typeof playerInstance[i][j] === 'function' && /"detailpage"!=/.test(playerInstance[i][j].toString())) { | |
// now that we find one of the two functions we will check which one | |
// we detect so we can manipulate it accordingly. | |
// there are two functions: one relays the dimensions to the progressbar | |
// elements and the other is for the video element size. | |
// they are almost identical, but there are small differences which | |
// we wil use to detect which one is for the progressbar and video, | |
// the later ends with !0) while the former doesn't, so we will use | |
// that information to regulate the functions' manipulation | |
if (/!0\)/.test(playerInstance[i][j].toString())) { | |
con.log('Progressbar: ' + j); | |
// here we simply wrap the original function to force it pass | |
// through our detour function before returning the size values. | |
// in this case I add a '' so that the detour function can tell which | |
// function is being called and change the sizes accordingly | |
playerInstance[i][j] = detour(playerInstance[i][j], ''); | |
} else if (!/!0\)/.test(playerInstance[i][j].toString())) { | |
con.log('Canvas: ' + j); | |
playerInstance[i][j] = detour(playerInstance[i][j]); | |
} | |
} | |
} | |
} | |
} | |
} catch (e) { | |
con.error(e); | |
} | |
} | |
function isNewPlayer() { | |
return (ytcenter.player.config && ytcenter.player.config.assets && ytcenter.player.config.assets.js && ytcenter.player.config.assets.js.indexOf("//s.ytimg.com/yts/jsbin/html5player-new-") === 0); | |
} | |
function fixPlayerSize() { | |
/*if (isNewPlayer()) {*/ | |
window.matchMedia = null; | |
/*} else { | |
patchDetour(); | |
}*/ | |
} | |
/* End Yonezpt glorious workaround */ | |
function load() { | |
if (!loadCalled) { | |
loadCalled = true; | |
playerAPI && playerAPI.setAttribute("id", "player-api"); | |
con.log("ytplayer.load() has been called."); | |
playerInstance = uw.yt.player.Application.create("player-api", uw.ytplayer.config); | |
uw.myPlayerInstance = playerInstance; | |
} | |
!createWrapped && fixPlayerSize(); | |
uw.ytplayer.config.loaded = true; | |
} | |
function playerLoadInjector() { | |
function getter() { | |
return load; | |
} | |
function setter(value) { | |
if (!loadCalled && ytcenter.html5 && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { | |
playerAPI = document.getElementById("player-api"); | |
playerAPI.setAttribute("id", "player-api-disabled"); | |
} | |
} | |
function addProp(noTimer) { | |
// We need to wrap yt.player.Application.create to be able to support SPF properly. However, a better method might be found. | |
if (uw.yt) { | |
if (propAdded) return; | |
propAdded = true; | |
addPropertyWrapper(uw.yt, "player.Application.create", function(instance){ | |
playerInstance = instance; | |
uw.myPlayerInstance = playerInstance; | |
fixPlayerSize(); | |
}, function(){ | |
createWrapped = true; | |
}); | |
} else { | |
!noTimer && !stopProp && setTimeout(addProp, 100); | |
} | |
} | |
var propAdded = false; | |
var stopProp = false; | |
addProp(); | |
ytcenter.playerInstance.setProperty("load", setter, getter); | |
ytcenter.pageReadinessListener.addEventListener("bodyComplete", function(){ | |
stopProp = true; | |
}); | |
ytcenter.pageReadinessListener.addEventListener("bodyInteractive", function(){ | |
addProp(true); | |
if (ytcenter.html5 && !(uw.yt && uw.yt.player && uw.yt.player.Application && uw.yt.player.Application.create)) { | |
ytcenter.insertScript(uw.ytplayer.config.assets.js, "html5player/html5player").onload(ytplayer.load); | |
ytcenter.insertStyle(uw.ytplayer.config.assets.css, "www-player"); | |
} | |
}); | |
} | |
var playerInstance = null; | |
var playerAPI = null; | |
var createWrapped = false; | |
var loadCalled = false; | |
// Always run this | |
playerLoadInjector(); | |
var exports = {}; | |
exports.load = load; | |
return exports; | |
})(); | |
// @utils | |
ytcenter.utils.getViewPort = function() { | |
var width = 0; | |
var height = 0; | |
if (typeof window.innerWidth === "number") { | |
width = window.innerWidth; | |
height = window.innerHeight; | |
} else if (document.documentElement && (document.documentElement.clientWidth || document.documentElement.clientHeight)) { | |
width = document.documentElement.clientWidth; | |
height = document.documentElement.clientHeight; | |
} else if (document.body && (document.body.clientWidth || document.body.clientHeight)) { | |
width = document.body.clientWidth; | |
height = document.body.clientHeight; | |
} | |
return { width: width, height: height }; | |
}; | |
ytcenter.utils.getAbsolutePosition = function(el) { | |
var x = el.offsetLeft || 0; | |
var y = el.offsetTop || 0; | |
if (el.offsetParent) { | |
var parentAbsolutePosition = ytcenter.utils.getAbsolutePosition(el.offsetParent); | |
x += parentAbsolutePosition.x; | |
y += parentAbsolutePosition.y; | |
} | |
return { x: x, y: y }; | |
}; | |
ytcenter.utils.listClass = function(el) { | |
if (!el || !el.className) return []; | |
return el.className.split(" "); | |
}; | |
ytcenter.utils.getLocationOrigin = function(){ | |
if (loc.origin) { | |
return loc.origin; | |
} else { | |
return loc.protocol + "//" + loc.hostname + (loc.port ? ":" + loc.port: ""); | |
} | |
}; | |
ytcenter.utils.getHTML5Player = function(){ | |
var movie_player = document.getElementById("movie_player"); | |
if (!movie_player) return null; | |
var video = movie_player.getElementsByClassName("html5-main-video")[0]; | |
return video || null; | |
}; | |
ytcenter.utils.errorProxy = function(scope, func){ | |
var args = Array.prototype.slice.call(arguments, 2); | |
return function(){ | |
try { | |
return func.apply(scope, args.concat(Array.prototype.slice.call(arguments))) | |
} catch (e) { | |
console.error(e); | |
} | |
}; | |
}; | |
ytcenter.utils.funcBind = function(scope, func){ | |
var args = Array.prototype.slice.call(arguments, 2); | |
return function(){ | |
return func.apply(scope, args.concat(Array.prototype.slice.call(arguments))) | |
}; | |
}; | |
(function(){ | |
var cssElements = {}; | |
ytcenter.utils.setCustomCSS = function(id, css){ | |
ytcenter.utils.removeCustomCSS(id); | |
if (css) { | |
var el = document.createElement("style"); | |
el.type = "text/css"; | |
el.textContent = css; | |
document.getElementsByTagName('head')[0].appendChild(el); | |
cssElements[id] = el; | |
} | |
}; | |
ytcenter.utils.removeCustomCSS = function(id){ | |
if (cssElements.hasOwnProperty(id)) { | |
cssElements[id].parentNode.removeChild(cssElements[id]); | |
delete cssElements[id]; | |
} | |
}; | |
})(); | |
(function(){ | |
function loadCanvas(url, rgba) { | |
var i; | |
for (i = 0; i < tintImages.length; i++) { | |
if (url === tintImages[i].url | |
&& rgba.r === tintImages[i].rgba.r | |
&& rgba.g === tintImages[i].rgba.g | |
&& rgba.b === tintImages[i].rgba.b | |
&& rgba.a === tintImages[i].rgba.a | |
) { | |
return tintImages[i].canvas; | |
} | |
} | |
} | |
var tintImages = []; | |
ytcenter.utils.tintImage = function(url, rgba, callback) { | |
function onerror() { | |
throw "Couldn't load image!"; | |
} | |
function onload() { | |
canvas.width = img.width; | |
canvas.height = img.height; | |
ctx.clearRect(0, 0, img.width, img.height); | |
ctx.drawImage(img, 0, 0, img.width, img.height); | |
var imageData = ctx.getImageData(0, 0, img.width, img.height); | |
var idx, i, pixel; | |
for (i = (img.width * img.height); i >= 0; --i) { | |
idx = i << 2; | |
pixel = {r: imageData.data[idx], g: imageData.data[idx + 1], b: imageData.data[idx + 2]}; | |
imageData.data[idx] = (rgba.a * rgba.r + (1 - rgba.a) * pixel.r); | |
imageData.data[idx + 1] = (rgba.a * rgba.g + (1 - rgba.a) * pixel.g); | |
imageData.data[idx + 2] = (rgba.a * rgba.b + (1 - rgba.a) * pixel.b); | |
} | |
ctx.putImageData(imageData, 0, 0); | |
tintImages.push({ url: url, rgba: rgba, canvas: canvas }); | |
if (tintImages.length > 10) tintImages.splice(0, tintImages.length - 10); | |
callback && callback(canvas); | |
} | |
var cache = loadCanvas(url, rgba); | |
if (cache) { | |
callback && callback(cache); | |
return; | |
} | |
var canvas = document.createElement("canvas"); | |
if (!(canvas.getContext && canvas.getContext('2d'))) return null; // Canvas is not supported! | |
var ctx = canvas.getContext("2d"); | |
var img = new Image(); | |
img.src = url; | |
img.onload = onload; | |
img.onerror = onerror; | |
}; | |
})(); | |
ytcenter.utils.setStyles = function(el, styles){ | |
var key; | |
for (key in styles) { | |
if (styles.hasOwnProperty(key)) { | |
el.style.setProperty(key, styles[key]) | |
} | |
} | |
}; | |
ytcenter.utils.filterColor = function(color, ohsv){ | |
var hsv = ytcenter.utils.getHSV(color.red, color.green, color.blue); | |
hsv.hue = Math.round(hsv.hue - ohsv.hue); | |
if (hsv.hue < 0) hsv.hue += 360; | |
hsv.saturation = Math.round(100 + (hsv.saturation - ohsv.saturation)); | |
hsv.value = Math.round(100 + (hsv.value - ohsv.value)); | |
return "hue-rotate(" + hsv.hue + "deg) saturate(" + hsv.saturation + "%) brightness(" + hsv.value + "%)"; | |
}; | |
ytcenter.utils.asyncCall = function(func){ | |
var args = Array.prototype.splice.call(arguments, 1, arguments.length); | |
var proxy = ytcenter.utils.oldBind(func); | |
uw.setTimeout(function(){ proxy.apply(null, args); }, 0); | |
}; | |
ytcenter.utils.getScrollPosition = function(scrollElm){ | |
var posX = 0; | |
var posY = 0; | |
while (scrollElm != null) { | |
posX += scrollElm.offsetLeft; | |
posY += scrollElm.offsetTop; | |
scrollElm = scrollElm.offsetParent; | |
} | |
return { x: posX, y: posY }; | |
}; | |
ytcenter.utils.live = (function(){ | |
function getElements(query) { | |
return document.querySelectorAll(query); | |
} | |
function isElementParent(el, parent) { | |
/*var found = false; | |
while (el && !(found = el === parent)) el = el.parentElement; | |
return found;*/ | |
return parent.contains(el); | |
} | |
function handleElements(elements, e, listener) { | |
var i; | |
for (i = 0; i < elements.length; i++) { | |
if (isElementParent(e.target, elements[i]) && typeof listener.listener === "function") { | |
listener.listener.call(e.target, e); | |
} | |
} | |
} | |
function onListener(e) { | |
var i; | |
e = e || win.event; | |
for (i = 0; i < listeners.length; i++) { | |
if (listeners[i].type === e.type) { | |
handleElements(getElements(listeners[i].query), e, listeners[i]); | |
} | |
} | |
} | |
function shutdown() { | |
listeners = []; | |
var i; | |
for (i = 0; i < events.length; i++) { | |
shutdownEvent(events[i]); | |
} | |
events = []; | |
} | |
function shutdownEvent(event) { | |
document.removeEventListener(event, onListener, false); | |
} | |
function setupEvent(event) { | |
if (!isEventInitialized(event)) { | |
document.addEventListener(event, onListener, false); | |
} | |
} | |
function clean(event) { | |
var i; | |
for (i = 0; i < listeners.length; i++) { | |
if (listeners[i].type === event) { | |
return; | |
} | |
} | |
shutdownEvent(event); | |
for (i = 0; i < events.length; i++) { | |
if (events[i] === event) { | |
events.splice(i, 1); | |
break; | |
} | |
} | |
} | |
function isEventInitialized(event) { | |
var i; | |
for (i = 0; i < events.length; i++) { | |
if (events[i] === event) | |
return true; | |
} | |
return false; | |
} | |
function addEventListener(type, query, listener) { | |
setupEvent(type); | |
listeners.push({ | |
type: type, | |
query: query, | |
listener: listener | |
}); | |
} | |
function removeEventListener(type, query, listener) { | |
var i; | |
for (i = 0; i < listeners.length; i++) { | |
if (type === listeners[i].type && query === listeners[i].query && listener === listeners[i].listener) { | |
listeners.splice(i, 1); | |
return; | |
} | |
} | |
} | |
var listeners = [], | |
events = []; | |
return { | |
add: addEventListener, | |
rem: removeEventListener, | |
unload: shutdown | |
}; | |
})(); | |
ytcenter.utils.setZeroTimeout = (function(){ | |
function setZeroTimeout(fn) { | |
timeouts.push(fn); | |
window.postMessage(uniqueMessageName, "*"); | |
} | |
function handleMessage(event) { | |
if ((event.source === window || event.source === uw) && event.data === uniqueMessageName) { | |
event && event.stopPropagation && event.stopPropagation(); | |
if (timeouts.length > 0) { | |
timeouts.shift()(); | |
} | |
} | |
} | |
var timeouts = [], | |
uniqueMessageName = "ytcenter-zero-timeout-message"; | |
window.addEventListener("message", handleMessage, true); | |
return setZeroTimeout; | |
})(); | |
ytcenter.utils.addEndTransitionListener = function(elm, listener){ | |
function getTransitionEndKey() { | |
var transitions = { | |
"transition": "transitionend", | |
"WebkitTransition": "webkitTransitionEnd", | |
"MozTransition": "transitionend", | |
"OTransition": "oTransitionEnd otransitionend" | |
}, key; | |
for (key in transitions) { | |
if (typeof elm.style[key] !== "undefined") { | |
return transitions[key]; | |
} | |
} | |
return null; | |
} | |
var transitionKey = getTransitionEndKey(); | |
if (transitionKey === null) return false; | |
transitionKey = transitionKey.split(" "); | |
ytcenter.utils.addEventListener(elm, transitionKey[0], listener, false); | |
if (transitionKey[1]) { | |
ytcenter.utils.addEventListener(elm, transitionKey[1], listener, false); | |
} | |
return true; | |
}; | |
ytcenter.utils.removeEndTransitionListener = function(elm, listener){ | |
function getTransitionEndKey() { | |
var transitions = { | |
"transition": "transitionend", | |
"WebkitTransition": "webkitTransitionEnd", | |
"MozTransition": "transitionend", | |
"OTransition": "oTransitionEnd otransitionend" | |
}, key; | |
for (key in transitions) { | |
if (typeof elm.style[key] !== "undefined") { | |
return transitions[key]; | |
} | |
} | |
return null; | |
} | |
var transitionKey = getTransitionEndKey(); | |
if (transitionKey === null) return false; | |
transitionKey = transitionKey.split(" "); | |
ytcenter.utils.removeEventListener(elm, transitionKey[0], listener, false); | |
if (transitionKey[1]) { | |
ytcenter.utils.removeEventListener(elm, transitionKey[1], listener, false); | |
} | |
return true; | |
}; | |
ytcenter.utils.urlComponentToObject = function(str){ | |
var parts = str.split("&"), | |
hash = {}, | |
i, | |
_tmp; | |
for (i = 0; i < parts.length; i++) { | |
_tmp = parts[i].split("="); | |
hash[decodeURIComponent(_tmp[0])] = decodeURIComponent(_tmp[1]); | |
} | |
return hash; | |
}; | |
ytcenter.utils.objectToUrlComponent = function(obj){ | |
var urlComponent = "", | |
key; | |
for (key in obj) { | |
if (obj.hasOwnProperty(key)) { | |
if (urlComponent !== "") urlComponent += "&"; | |
urlComponent += encodeURIComponent(key) + "=" + encodeURIComponent(obj[key]); | |
} | |
} | |
return urlComponent; | |
}; | |
ytcenter.utils.cssFix = function(elm){ | |
var width = elm.style.width; | |
elm.style.width = "0px"; | |
elm.offsetHeight; | |
elm.style.width = (width ? width : ""); | |
}; | |
ytcenter.utils.getContentByTags = function(text, startTag, endTag){ | |
text = text.split(startTag)[1]; | |
text = text.split(endTag)[0]; | |
return text; | |
}; | |
ytcenter.utils.cleanObject = function(obj){ | |
try { | |
if (obj instanceof Object && typeof obj["__exposedProps__"] !== "undefined") delete obj["__exposedProps__"]; | |
} catch (e) { | |
con.error(e); | |
} | |
var key; | |
for (key in obj) { | |
if (!obj.hasOwnProperty(key)) { | |
delete obj[key]; | |
} else { | |
if (key === "__exposedProps__") { | |
delete obj[key]; | |
} else if (obj[key] instanceof Object) { | |
obj[key] = ytcenter.utils.cleanObject(obj[key]); | |
} | |
} | |
} | |
return obj; | |
}; | |
ytcenter.utils.setCaretPosition = function(el, pos){ | |
if (pos < 0) pos = 0; | |
if (pos > el.value.length) pos = el.value.length; | |
if (typeof el.selectionStart === "number") { | |
el.selectionStart = pos; | |
el.selectionEnd = pos; | |
} else if (document.selection) { | |
el.focus(); | |
var sel = document.selection.createRange(); | |
sel.moveStart("character", pos); | |
sel.moveEnd("character", 0); | |
sel.select(); | |
} | |
}; | |
ytcenter.utils.getCaretPosition = function(el){ | |
var pos = 0; | |
if (typeof el.selectionStart === "number") { | |
pos = el.selectionStart; | |
} else if (document.selection) { | |
el.focus(); | |
var sel = document.selection.createRange(); | |
sel.moveStart("character", -el.value.length); | |
pos = sel.text.length; | |
} | |
return pos; | |
}; | |
ytcenter.utils.prefixText = function(text, prefixChar, preferedLength){ | |
var t = ("" + text); | |
if (t.length < preferedLength) { | |
var i; | |
for (i = 0; i < preferedLength - t.length; i++) { | |
t = prefixChar + t; | |
} | |
} | |
return t; | |
}; | |
ytcenter.utils.replaceContent = function(content, data, start, end) { | |
var a = content.indexOf(start) | |
b = content.indexOf(end); | |
return content.substring(0, a + start.length) + JSON.stringify(data) + content.substring(b); | |
} | |
/* Code taken from https://code.google.com/p/doctype-mirror/wiki/ArticleNodeContains */ | |
ytcenter.utils.contains = function(parent, descendant){ | |
// W3C DOM Level 3 | |
if (typeof parent.compareDocumentPosition != 'undefined') { | |
return parent == descendant || Boolean(parent.compareDocumentPosition(descendant) & 16); | |
} | |
// W3C DOM Level 1 | |
while (descendant && parent != descendant) { | |
descendant = descendant.parentNode; | |
} | |
return descendant == parent; | |
}; | |
ytcenter.utils.toArray = function(list){ | |
var arr = [], i, len = list.length; | |
for (i = 0; i < len; i++) { | |
arr.push(list[i]); | |
} | |
return arr; | |
}; | |
ytcenter.utils.scrollTop = function(scrollTop){ | |
if (!document) return null; | |
if (typeof scrollTop === "number") { | |
con.log("[scrollTop] Scrolling to y-position: " + scrollTop); | |
window.scroll(0, scrollTop); | |
} else if (typeof scrollTop === "object" && scrollTop.scrollIntoView) { | |
con.log("[scrollTop] Scrolling to element."); | |
scrollTop.scrollIntoView(true); | |
} | |
if (document.body && typeof document.body.scrollTop === "number") { | |
return document.body.scrollTop; | |
} else { | |
return document.documentElement.scrollTop; | |
} | |
}; | |
/** | |
* Checks if an element is a child of parent. | |
* | |
* @method isParent | |
* @param {HTMLElement} parent The parent element. | |
* @param {HTMLElement} child The child element. | |
* @return {Boolean} Returns true if the child element is a child of the parent element. | |
**/ | |
ytcenter.utils.isParent = function(parent, child){ | |
if (parent && child && typeof parent.contains === "function") { | |
return parent.contains(child); | |
} | |
var children = parent.getElementsByTagName(child.tagName); | |
for (var i = 0, len = children.length; i < len; i++) { | |
if (children[i] === child) { | |
return true; | |
} | |
} | |
return false; | |
}; | |
ytcenter.utils.once = function(func) { | |
var ran = false, memo; | |
return function() { | |
if (ran) return memo; | |
ran = true; | |
memo = func.apply(this, arguments); | |
func = null; | |
return memo; | |
}; | |
}; | |
ytcenter.utils.isContainerOverflowed = function(a){ // Possible going to use this one | |
// AKA Is the container bigger on the inside than the outside? | |
return { | |
x: a.scrollWidth > a.clientWidth, | |
y: a.scrollHeight > a.clientHeight | |
}; | |
}; | |
ytcenter.utils.isScrollable = function(a){ | |
var b = ytcenter.utils.getOverflow(a); | |
if (!b.x && !b.y) return false; | |
return { | |
x: b.x && a.scrollWidth > a.clientWidth, | |
y: b.y && a.scrollHeight > a.clientHeight | |
}; | |
}; | |
ytcenter.utils.getOverflow = function(a){ | |
var b = ytcenter.utils.getComputedStyles(a), | |
c = { | |
auto: true, | |
scroll: true, | |
visible: false, | |
hidden: false | |
}; | |
return { x: c[b.overflowX.toLowerCase()], y: c[b.overflowY.toLowerCase()] }; | |
}; | |
ytcenter.utils.getComputedStyles = function(a){ | |
if (!a) return {}; | |
if (document && document.defaultView && document.defaultView.getComputedStyle) | |
return document.defaultView.getComputedStyle(a, null); | |
return a.currentStyle; | |
}; | |
ytcenter.utils.getComputedStyle = function(a, b) { | |
return ytcenter.utils.getComputedStyles(a)[b]; | |
}; | |
ytcenter.utils.getBoundingClientRect = function(a) { | |
var b; | |
if (!a) return null; | |
try { | |
b = a.getBoundingClientRect(); | |
b = { | |
left: b.left, | |
top: b.top, | |
right: b.right, | |
bottom: b.bottom | |
}; | |
} catch (c) { | |
return { | |
left: 0, | |
top: 0, | |
right: 0, | |
bottom: 0 | |
} | |
} | |
if (a.ownerDocument.body) { | |
a = a.ownerDocument; | |
b.left -= a.documentElement.clientLeft + a.body.clientLeft; | |
b.top -= a.documentElement.clientTop + a.body.clientTop; | |
} | |
return b; | |
}; | |
ytcenter.utils.getDimension = function(elm){ | |
if (!elm) return { width: 0, height: 0 }; | |
return { width: elm.offsetWidth, height: elm.offsetHeight }; | |
}; | |
ytcenter.utils.isElementPartlyInView = function(elm, offset, winDim){ | |
var box = ytcenter.utils.getBoundingClientRect(elm) || { left: 0, top: 0, right: 0, bottom: 0 }, | |
dim = ytcenter.utils.getDimension(elm), a = elm, b, c, d; | |
offset = offset || { top: 0, left: 0 }; | |
winDim = winDim || {width: window.innerWidth || document.documentElement.clientWidth, height: window.innerHeight || document.documentElement.clientHeight }; | |
return (box.top + offset.top >= 0 - dim.height | |
&& box.left + offset.left >= 0 - dim.width | |
&& box.bottom + offset.top <= winDim.height + dim.height | |
&& box.right + offset.left <= winDim.width + dim.width); | |
}; | |
ytcenter.utils.isElementInView = function(elm){ // TODO Implement scrollable elements support. | |
if (ytcenter.utils.getComputedStyle(elm, "display").toLowerCase() === "none") | |
return false; | |
var box = ytcenter.utils.getBoundingClientRect(elm) || { left: 0, top: 0, right: 0, bottom: 0 }, a = elm, b, c; | |
while (!!(a = a.parentNode) && a !== document.body) { | |
if (ytcenter.utils.getComputedStyle(a, "display").toLowerCase() === "none") | |
return false; | |
b = ytcenter.utils.isContainerOverflowed(a); | |
if (b.x || b.y) { | |
c = ytcenter.utils.getBoundingClientRect(a) || { left: 0, top: 0, right: 0, bottom: 0 }; | |
c.top = c.top - box.top + a.scrollTop; | |
c.left = c.left - box.left + a.scrollLeft; | |
c.bottom = c.bottom - box.bottom + a.scrollTop; | |
c.right = c.right - box.right + a.scrollLeft; | |
if (!(c.top >= 0 && c.left >= 0 && c.bottom <= a.clientHeight && c.right <= a.clientWidth)) | |
return false; | |
// We now know that the element is visible in the parent and therefore we can just check if the parent is visible ~magic. | |
return ytcenter.utils.isElementInView(a); | |
} | |
}; | |
return (box.top >= 0 | |
&& box.left >= 0 | |
&& box.bottom <= (window.innerHeight || document.documentElement.clientHeight) | |
&& box.right <= (window.innerWidth || document.documentElement.clientWidth)); | |
}; | |
ytcenter.utils.getVideoIdFromLink = function(url){ | |
var videoIdRegex = /v=([a-zA-Z0-9-_]+)/, | |
indexRegex = /index=([0-9]+)/, | |
videoIdsRegex = /video_ids=([0-9a-zA-Z-_%]+)/, | |
i = 0, a; | |
if (url.match(videoIdRegex)) { | |
a = videoIdRegex.exec(url); | |
if (a && a[1]) return a[1]; | |
} else if (url.match(videoIdsRegex)) { | |
a = indexRegex.exec(url); | |
if (a && a[1]) { | |
i = parseInt(a[1]); | |
} | |
a = videoIdsRegex.exec(url); | |
if (a && a[1] && a[1].split("%2C").length > 0 && a[1].split("%2C")[i]) { | |
return a[1].split("%2C")[i]; | |
} | |
} | |
return null; | |
}; | |
ytcenter.utils.replaceTextAsString = function(text, rep) { | |
if (!text) return text; | |
var tmp = ""; | |
var startB = false; | |
var func = ""; | |
var tmpName = ""; | |
var tmpFunc = ""; | |
var inFunc = false; | |
for (var i = 0; i < text.length; i++) { | |
if (text.charAt(i) == "{" && !startB && !inFunc) { | |
startB = true; | |
} else if (text.charAt(i) == "}" && startB) { | |
var t = tmpName; | |
for (var key in rep) { | |
if (rep.hasOwnProperty(key)) { | |
if (key === tmpName) { | |
tmpName = ""; | |
t = rep[key]; | |
break; | |
} | |
} | |
} | |
tmp += t; | |
startB = false; | |
} else if (startB) { | |
if (tmpName == "" && text.charAt(i) == "!") { | |
tmp += "{"; | |
startB = false; | |
} else { | |
tmpName += text.charAt(i); | |
} | |
} else { | |
tmp += text.charAt(i); | |
} | |
} | |
return tmp; | |
}; | |
ytcenter.utils.replaceTextToText = function(text, replacer){ | |
var regex, arr = [], tmp = ""; | |
text = text || ""; | |
for (key in replacer) { | |
if (replacer.hasOwnProperty(key)) { | |
arr.push(ytcenter.utils.escapeRegExp(key)); | |
} | |
} | |
regex = new RegExp(arr.join("|") + "|.", "g"); | |
text.replace(regex, function(matched){ | |
if (replacer[matched]) { | |
if (typeof replacer[matched] === "function") { | |
var a = replacer[matched](); | |
if (typeof a === "string") { | |
tmp += a; | |
} else { | |
con.error("[TextReplace] Unknown type of replacer!"); | |
} | |
} else if (typeof replacer[matched] === "string") { | |
tmp += replacer[matched]; | |
} else if (typeof replacer[matched] === "number") { | |
tmp += replacer[matched]; | |
} else { | |
con.error("[TextReplace] Unknown type of replacer!"); | |
} | |
} else { | |
tmp += matched; | |
} | |
}); | |
return tmp; | |
}; | |
ytcenter.utils.guid = function(){ | |
function S4() { | |
return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1); | |
} | |
return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4(); | |
}; | |
ytcenter.utils.srtTimeFormat = function(totalSeconds){ | |
var sec_num = Math.floor(totalSeconds), | |
hours = Math.floor(sec_num / 3600), | |
minutes = Math.floor((sec_num - (hours * 3600)) / 60), | |
seconds = sec_num - (hours * 3600) - (minutes * 60), | |
milliseconds = Math.round((totalSeconds - sec_num)*100); | |
if (hours < 10) hours = "0" + hours; | |
if (minutes < 10) minutes = "0" + minutes; | |
if (seconds < 10) seconds = "0" + seconds; | |
if (milliseconds < 100) milliseconds = "0" + milliseconds; | |
if (milliseconds < 10) milliseconds = "0" + milliseconds; | |
return hours + ":" + minutes + ":" + seconds + "," + milliseconds; | |
}; | |
ytcenter.utils.parseXML = function(rawxml){ | |
var doc; | |
if (uw.DOMParser) { | |
var parser = new uw.DOMParser(); | |
doc = parser.parseFromString(rawxml, "text/xml"); | |
} else if (uw.ActiveXObject) { | |
doc = new uw.ActiveXObject("Microsoft.XMLDOM"); | |
doc.async = false; | |
doc.loadXML(rawxml); | |
} else { | |
throw new Error("[XMLParser] Cannot parse XML!"); | |
} | |
return doc; | |
}; | |
ytcenter.utils.getURL = function(url){ | |
var a = document.createElement("a"); | |
a.href = url; | |
return a; | |
}; | |
ytcenter.utils.wrapModule = function(module, tagname){ | |
var a = document.createElement(tagname || "span"); | |
a.appendChild(module.element); | |
return a; | |
}; | |
ytcenter.utils.transformToArray = function(domArray){ | |
var a = [], i; | |
for (i = 0; i < domArray.length; i++) { | |
a.push(domArray[i]); | |
} | |
return a; | |
}; | |
ytcenter.utils.decodeHTML = function(a){ | |
return a.replace(/&([^;]+);/g, function(a, c){ | |
switch (c) { | |
case "amp": | |
return "&"; | |
case "lt": | |
return "<"; | |
case "gt": | |
return ">"; | |
case "quot": | |
return '"'; | |
default: | |
if ("#" == c.charAt(0)) { | |
var d = Number("0" + c.substr(1)); | |
if (!isNaN(d)) return String.fromCharCode(d) | |
} | |
return a | |
} | |
}) | |
}; | |
ytcenter.utils.decode = function(a){ | |
var b = { | |
"&": "&", | |
"<": "<", | |
">": ">", | |
""": '"' | |
}, c = window.document.createElement("div"); | |
return a.replace(/&([^;\s<&]+);?/g, function(a, e){ | |
var g = b[a]; | |
if (g) return g; | |
if ("#" == e.charAt(0)) { | |
var h = Number("0" + e.substr(1)); | |
(0, window.isNaN)(h) || (g = String.fromCharCode(h)) | |
} | |
g || (c.innerHTML = a + " ", g = c.firstChild.nodeValue.slice(0, -1)); | |
return b[a] = g | |
}) | |
}; | |
ytcenter.utils.encodeRawTag = function(text){ | |
var a = document.createElement("a"), | |
b = document.createElement("div"); | |
a.setAttribute("class", text); | |
b.appendChild(a); | |
return b.innerHTML.substring("<a class=\"".length, b.innerHTML.length - "\"></a>".length); | |
}; | |
ytcenter.utils.decodeRawTag = function(text){ | |
var a = document.createElement("div"); | |
a.innerHTML = "<a class=\"" + text + "\"></a>"; | |
return a.firstChild.getAttribute("class"); | |
}; | |
ytcenter.utils.setterGetterClassCompatible = function(){ | |
try { | |
var a_getter = false, a_setter = false, a_instance, a_confirm = "WORKS"; | |
a_instance = defineLockedProperty({}, "test", function(value){a_setter = value === a_confirm}, function(){a_getter = true;return a_confirm;}); | |
if (a_confirm === a_instance.test) { | |
a_instance.test = a_confirm; | |
if (a_getter && a_setter) | |
return true; | |
} | |
} catch (e) { | |
con.error(e); | |
return false; | |
} | |
return false; | |
}; | |
ytcenter.utils.isNode = function(a){ | |
if (typeof Node === "object") { | |
return a instanceof Node; | |
} else if (a && typeof a === "object" && typeof a.nodeType === "number" && typeof a.nodeName === "string") { | |
return true; | |
} | |
return false; | |
}; | |
ytcenter.utils.escapeRegExp = function(str) { | |
return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"); | |
}; | |
ytcenter.utils.replaceTextAsString = function(text, rep) { | |
if (!text) return text; | |
var tmp = ""; | |
var startB = false; | |
var func = ""; | |
var tmpName = ""; | |
var tmpFunc = ""; | |
var inFunc = false; | |
for (var i = 0; i < text.length; i++) { | |
if (text.charAt(i) == "{" && !startB && !inFunc) { | |
startB = true; | |
} else if (text.charAt(i) == "}" && startB) { | |
var t = tmpName; | |
for (var key in rep) { | |
if (rep.hasOwnProperty(key)) { | |
if (key === tmpName) { | |
tmpName = ""; | |
t = rep[key]; | |
break; | |
} | |
} | |
} | |
tmp += t; | |
startB = false; | |
} else if (startB) { | |
if (tmpName == "" && text.charAt(i) == "!") { | |
tmp += "{"; | |
startB = false; | |
} else { | |
tmpName += text.charAt(i); | |
} | |
} else { | |
tmp += text.charAt(i); | |
} | |
} | |
return tmp; | |
}; | |
/** This will replace strings in a text with other strings or HTML elements. | |
* replacer : { | |
* "__REPLACEDSTRING__": document.createElement("div"), | |
* "{REPLACESTRING}": "ANOTHER STRING" | |
* } | |
*/ | |
ytcenter.utils.replaceText = function(text, replacer){ | |
var frag = document.createDocumentFragment(), | |
regex, arr = [], tmp = ""; | |
for (key in replacer) { | |
if (replacer.hasOwnProperty(key)) { | |
arr.push(ytcenter.utils.escapeRegExp(key)); | |
} | |
} | |
regex = new RegExp(arr.join("|") + "|.", "g"); | |
text.replace(regex, function(matched){ | |
if (replacer[matched]) { | |
if (tmp !== "") { | |
frag.appendChild(document.createTextNode(tmp)); | |
tmp = ""; | |
} | |
if (typeof replacer[matched] === "function") { | |
var a = replacer[matched](); | |
if (typeof a === "string") { | |
frag.appendChild(document.createTextNode(a)); | |
} else if (ytcenter.utils.isNode(a)) { | |
frag.appendChild(a); | |
} else { | |
con.error("[TextReplace] Unknown type of replacer!"); | |
} | |
} else if (typeof replacer[matched] === "string") { | |
frag.appendChild(document.createTextNode(replacer[matched])); | |
} else if (ytcenter.utils.isNode(replacer[matched])) { | |
frag.appendChild(replacer[matched]); | |
} else { | |
con.error("[TextReplace] Unknown type of replacer!"); | |
} | |
} else { | |
tmp += matched; | |
} | |
}); | |
if (tmp !== "") { | |
frag.appendChild(document.createTextNode(tmp)); | |
tmp = ""; | |
} | |
return frag; | |
}; | |
ytcenter.utils._escape_html_entities = [ | |
[" ", "¡", "¢", "£", "¤", "¥", "¦", "§", "¨", "©", "ª", "«", "¬", "­", "®", "¯", "°", "±", "²", "³", "´", "µ", "¶", "·", "¸", "¹", "º", "»", "¼", "½", "¾", "¿", "À", "Á", "Â", "Ã", "Ä", "Å", "Æ", "Ç", "È", "É", "Ê", "Ë", "Ì", "Í", "Î", "Ï", "Ð", "Ñ", "Ò", "Ó", "Ô", "Õ", "Ö", "×", "Ø", "Ù", "Ú", "Û", "Ü", "Ý", "Þ", "ß", "à", "á", "â", "ã", "ä", "å", "æ", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", "ð", "ñ", "ò", "ó", "ô", "õ", "ö", "÷", "ø", "ù", "ú", "û", "ü", "ý", "þ", "ÿ", """, "&", "<", ">", "Œ", "œ", "Š", "š", "Ÿ", "ˆ", "˜", " ", " ", " ", "‌", "‍", "‎", "‏", "–", "—", "‘", "’", "‚", "“", "”", "„", "†", "‡", "‰", "‹", "›", "€", "ƒ", "Α", "Β", "Γ", "Δ", "Ε", "Ζ", "Η", "Θ", "Ι", "Κ", "Λ", "Μ", "Ν", "Ξ", "Ο", "Π", "Ρ", "Σ", "Τ", "Υ", "Φ", "Χ", "Ψ", "Ω", "α", "β", "γ", "δ", "ε", "ζ", "η", "θ", "ι", "κ", "λ", "μ", "ν", "ξ", "ο", "π", "ρ", "ς", "σ", "τ", "υ", "φ", "χ", "ψ", "ω", "ϑ", "ϒ", "ϖ", "•", "…", "′", "″", "‾", "⁄", "℘", "ℑ", "ℜ", "™", "ℵ", "←", "↑", "→", "↓", "↔", "↵", "⇐", "⇑", "⇒", "⇓", "⇔", "∀", "∂", "∃", "∅", "∇", "∈", "∉", "∋", "∏", "∑", "−", "∗", "√", "∝", "∞", "∠", "∧", "∨", "∩", "∪", "∫", "∴", "∼", "≅", "≈", "≠", "≡", "≤", "≥", "⊂", "⊃", "⊄", "⊆", "⊇", "⊕", "⊗", "⊥", "⋅", "⌈", "⌉", "⌊", "⌋", "⟨", "⟩", "◊", "♠", "♣", "♥", "♦"], | |
[" ", "¡", "¢", "£", "¤", "¥", "¦", "§", "¨", "©", "ª", "«", "¬", "­", "®", "¯", "°", "±", "²", "³", "´", "µ", "¶", "·", "¸", "¹", "º", "»", "¼", "½", "¾", "¿", "À", "Á", "Â", "Ã", "Ä", "Å", "Æ", "Ç", "È", "É", "Ê", "Ë", "Ì", "Í", "Î", "Ï", "Ð", "Ñ", "Ò", "Ó", "Ô", "Õ", "Ö", "×", "Ø", "Ù", "Ú", "Û", "Ü", "Ý", "Þ", "ß", "à", "á", "â", "ã", "ä", "å", "æ", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", "ð", "ñ", "ò", "ó", "ô", "õ", "ö", "÷", "ø", "ù", "ú", "û", "ü", "ý", "þ", "ÿ", """, "&", "<", ">", "Œ", "œ", "Š", "š", "Ÿ", "ˆ", "˜", " ", " ", " ", "‌", "‍", "‎", "‏", "–", "—", "‘", "’", "‚", "“", "”", "„", "†", "‡", "‰", "‹", "›", "€", "ƒ", "Α", "Β", "Γ", "Δ", "Ε", "Ζ", "Η", "Θ", "Ι", "Κ", "Λ", "Μ", "Ν", "Ξ", "Ο", "Π", "Ρ", "Σ", "Τ", "Υ", "Φ", "Χ", "Ψ", "Ω", "α", "β", "γ", "δ", "ε", "ζ", "η", "θ", "ι", "κ", "λ", "& |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment