Skip to content

Instantly share code, notes, and snippets.

@mikhoul
Created August 20, 2017 16:56
Show Gist options
  • Save mikhoul/41122d22b9e731400b164a3ed8344d8e to your computer and use it in GitHub Desktop.
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.
/**
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 ? "&nbsp;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 ? "&nbsp;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 ? "&nbsp;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(/&amp;/g, "&").replace(/&quot;/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 = {
"&amp;": "&",
"&lt;": "<",
"&gt;": ">",
"&quot;": '"'
}, 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 = [
["&nbsp;", "&iexcl;", "&cent;", "&pound;", "&curren;", "&yen;", "&brvbar;", "&sect;", "&uml;", "&copy;", "&ordf;", "&laquo;", "&not;", "&shy;", "&reg;", "&macr;", "&deg;", "&plusmn;", "&sup2;", "&sup3;", "&acute;", "&micro;", "&para;", "&middot;", "&cedil;", "&sup1;", "&ordm;", "&raquo;", "&frac14;", "&frac12;", "&frac34;", "&iquest;", "&Agrave;", "&Aacute;", "&Acirc;", "&Atilde;", "&Auml;", "&Aring;", "&AElig;", "&Ccedil;", "&Egrave;", "&Eacute;", "&Ecirc;", "&Euml;", "&Igrave;", "&Iacute;", "&Icirc;", "&Iuml;", "&ETH;", "&Ntilde;", "&Ograve;", "&Oacute;", "&Ocirc;", "&Otilde;", "&Ouml;", "&times;", "&Oslash;", "&Ugrave;", "&Uacute;", "&Ucirc;", "&Uuml;", "&Yacute;", "&THORN;", "&szlig;", "&agrave;", "&aacute;", "&acirc;", "&atilde;", "&auml;", "&aring;", "&aelig;", "&ccedil;", "&egrave;", "&eacute;", "&ecirc;", "&euml;", "&igrave;", "&iacute;", "&icirc;", "&iuml;", "&eth;", "&ntilde;", "&ograve;", "&oacute;", "&ocirc;", "&otilde;", "&ouml;", "&divide;", "&oslash;", "&ugrave;", "&uacute;", "&ucirc;", "&uuml;", "&yacute;", "&thorn;", "&yuml;", "&quot;", "&amp;", "&lt;", "&gt;", "&OElig;", "&oelig;", "&Scaron;", "&scaron;", "&Yuml;", "&circ;", "&tilde;", "&ensp;", "&emsp;", "&thinsp;", "&zwnj;", "&zwj;", "&lrm;", "&rlm;", "&ndash;", "&mdash;", "&lsquo;", "&rsquo;", "&sbquo;", "&ldquo;", "&rdquo;", "&bdquo;", "&dagger;", "&Dagger;", "&permil;", "&lsaquo;", "&rsaquo;", "&euro;", "&fnof;", "&Alpha;", "&Beta;", "&Gamma;", "&Delta;", "&Epsilon;", "&Zeta;", "&Eta;", "&Theta;", "&Iota;", "&Kappa;", "&Lambda;", "&Mu;", "&Nu;", "&Xi;", "&Omicron;", "&Pi;", "&Rho;", "&Sigma;", "&Tau;", "&Upsilon;", "&Phi;", "&Chi;", "&Psi;", "&Omega;", "&alpha;", "&beta;", "&gamma;", "&delta;", "&epsilon;", "&zeta;", "&eta;", "&theta;", "&iota;", "&kappa;", "&lambda;", "&mu;", "&nu;", "&xi;", "&omicron;", "&pi;", "&rho;", "&sigmaf;", "&sigma;", "&tau;", "&upsilon;", "&phi;", "&chi;", "&psi;", "&omega;", "&thetasym;", "&upsih;", "&piv;", "&bull;", "&hellip;", "&prime;", "&Prime;", "&oline;", "&frasl;", "&weierp;", "&image;", "&real;", "&trade;", "&alefsym;", "&larr;", "&uarr;", "&rarr;", "&darr;", "&harr;", "&crarr;", "&lArr;", "&uArr;", "&rArr;", "&dArr;", "&hArr;", "&forall;", "&part;", "&exist;", "&empty;", "&nabla;", "&isin;", "&notin;", "&ni;", "&prod;", "&sum;", "&minus;", "&lowast;", "&radic;", "&prop;", "&infin;", "&ang;", "&and;", "&or;", "&cap;", "&cup;", "&int;", "&there4;", "&sim;", "&cong;", "&asymp;", "&ne;", "&equiv;", "&le;", "&ge;", "&sub;", "&sup;", "&nsub;", "&sube;", "&supe;", "&oplus;", "&otimes;", "&perp;", "&sdot;", "&lceil;", "&rceil;", "&lfloor;", "&rfloor;", "&lang;", "&rang;", "&loz;", "&spades;", "&clubs;", "&hearts;", "&diams;"],
["&#160;", "&#161;", "&#162;", "&#163;", "&#164;", "&#165;", "&#166;", "&#167;", "&#168;", "&#169;", "&#170;", "&#171;", "&#172;", "&#173;", "&#174;", "&#175;", "&#176;", "&#177;", "&#178;", "&#179;", "&#180;", "&#181;", "&#182;", "&#183;", "&#184;", "&#185;", "&#186;", "&#187;", "&#188;", "&#189;", "&#190;", "&#191;", "&#192;", "&#193;", "&#194;", "&#195;", "&#196;", "&#197;", "&#198;", "&#199;", "&#200;", "&#201;", "&#202;", "&#203;", "&#204;", "&#205;", "&#206;", "&#207;", "&#208;", "&#209;", "&#210;", "&#211;", "&#212;", "&#213;", "&#214;", "&#215;", "&#216;", "&#217;", "&#218;", "&#219;", "&#220;", "&#221;", "&#222;", "&#223;", "&#224;", "&#225;", "&#226;", "&#227;", "&#228;", "&#229;", "&#230;", "&#231;", "&#232;", "&#233;", "&#234;", "&#235;", "&#236;", "&#237;", "&#238;", "&#239;", "&#240;", "&#241;", "&#242;", "&#243;", "&#244;", "&#245;", "&#246;", "&#247;", "&#248;", "&#249;", "&#250;", "&#251;", "&#252;", "&#253;", "&#254;", "&#255;", "&#34;", "&#38;", "&#60;", "&#62;", "&#338;", "&#339;", "&#352;", "&#353;", "&#376;", "&#710;", "&#732;", "&#8194;", "&#8195;", "&#8201;", "&#8204;", "&#8205;", "&#8206;", "&#8207;", "&#8211;", "&#8212;", "&#8216;", "&#8217;", "&#8218;", "&#8220;", "&#8221;", "&#8222;", "&#8224;", "&#8225;", "&#8240;", "&#8249;", "&#8250;", "&#8364;", "&#402;", "&#913;", "&#914;", "&#915;", "&#916;", "&#917;", "&#918;", "&#919;", "&#920;", "&#921;", "&#922;", "&#923;", "&#924;", "&#925;", "&#926;", "&#927;", "&#928;", "&#929;", "&#931;", "&#932;", "&#933;", "&#934;", "&#935;", "&#936;", "&#937;", "&#945;", "&#946;", "&#947;", "&#948;", "&#949;", "&#950;", "&#951;", "&#952;", "&#953;", "&#954;", "&#955;", "&
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment