update.greasyfork.org
Open in
urlscan Pro
2600:3c01:1::68c8:1b31
Public Scan
URL:
https://update.greasyfork.org/scripts/943/YouTube%20Center.user.js
Submission: On November 28 via api from LU — Scanned from DE
Submission: On November 28 via api from LU — Scanned from DE
Form analysis
0 forms found in the DOMText Content
/** The MIT License (MIT) Copyright (c) 2014 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 // @name YouTube Center // @namespace http://www.facebook.com/YouTubeCenter // @version 2.1.7 // @author Jeppe Rune Mortensen <jepperm@gmail.com> // @description YouTube Center 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_getResourceText // @grant GM_log // @grant GM_registerMenuCommand // @grant unsafeWindow // @updateVersion 156 // @run-at document-start // @priority 9001 // @contributionURL https://github.com/YePpHa/YouTubeCenter/wiki/Donate // @license MIT // @resource translations https://yeppha.github.io/downloads/translations.json // @downloadURL https://update.greasyfork.org/scripts/943/YouTube%20Center.user.js // @updateURL https://update.greasyfork.org/scripts/943/YouTube%20Center.meta.js // ==/UserScript== (function(){ "use strict"; function inject(func) { var script = document.createElement("script"); var p = document.body || document.head || document.documentElement; if (!p) { setTimeout(bind(null, inject, func), 0); return; } script.setAttribute("type", "text/javascript"); if (typeof func === "string") { func = "function(){" + func + "}"; } script.appendChild(document.createTextNode("(" + func + ")(true, 0, false, 406, " + GM_getResourceText("translations") + ");\n//# sourceURL=YouTubeCenter.js")); p.appendChild(script); p.removeChild(script); } var main_function = function(injected, identifier, devbuild, devnumber, ytcenter_locales, _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 $HasAttribute(elm, attr) { var i; for (i = 0; i < elm.attributes.length; i++) { if (elm.attributes[i].name == attr) return true; } return false; } function $GetOffset(elm) { var x = 0, y = 0; while (elm != null) { y += elm.offsetTop; x += elm.offsetLeft; elm = elm.offsetParent; } return [x, y]; } 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 (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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")) + " - " + (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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.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.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 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.split("x")[1] + "p", stream_dimension: stream.dimension, stream_3d: (stream.stereo3d && stream.stereo3d == 1 ? " 3D" : ""), stream_type: (function(stream){ for (var i = 0; i < ytcenter.video.format.length; i++) { if (stream.type.indexOf(ytcenter.video.format[i].type) == 0) { return ytcenter.language.getLocale(ytcenter.video.format[i].name); } } return ytcenter.language.getLocale("UNKNOWN"); })(stream) }); } else { btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP_NONE"), { type: (function(){ for (var i = 0; i < ytcenter.video.format.length; i++) { if (ytcenter.settings.downloadFormat == ytcenter.video.format[i].key) { return ytcenter.language.getLocale(ytcenter.video.format[i].name); } } return ytcenter.language.getLocale("UNKNOWN"); })() }); } ytcenter.events.addEvent("ui-refresh", function(){ var stream = $DownloadButtonStream(); if (stream != null) { var stream_name = { highres: ytcenter.language.getLocale("HIGHRES"), hd1440: ytcenter.language.getLocale("HD1440"), hd1080: ytcenter.language.getLocale("HD1080"), hd720: ytcenter.language.getLocale("HD720"), large: ytcenter.language.getLocale("LARGE"), medium: ytcenter.language.getLocale("MEDIUM"), small: ytcenter.language.getLocale("SMALL") }[stream.quality]; btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP"), { stream_name: stream_name, stream_resolution: stream.dimension.split("x")[1] + "p", stream_dimension: stream.dimension, stream_3d: (stream.stereo3d && stream.stereo3d == 1 ? " 3D" : ""), stream_type: (function(stream){ for (var i = 0; i < ytcenter.video.format.length; i++) { if (stream.type.indexOf(ytcenter.video.format[i].type) == 0) { return ytcenter.language.getLocale(ytcenter.video.format[i].name); } } return ytcenter.language.getLocale("UNKNOWN"); })(stream) }); } else { btn1.title = ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("BUTTON_DOWNLOAD_TOOLTIP_NONE"), { type: (function(){ for (var i = 0; i < ytcenter.video.format.length; i++) { if (ytcenter.settings.downloadFormat == ytcenter.video.format[i].key) { return ytcenter.language.getLocale(ytcenter.video.format[i].name); } } return ytcenter.language.getLocale("UNKNOWN"); })() }); } }); btn1a.appendChild(btn1); var btn1_text = document.createElement("span"); btn1_text.className = "yt-uix-button-content"; btn1_text.textContent = ytcenter.language.getLocale("BUTTON_DOWNLOAD_TEXT"); ytcenter.language.addLocaleElement(btn1_text, "BUTTON_DOWNLOAD_TEXT", "@textContent"); btn1.appendChild(btn1_text); g.appendChild(btn1a); var btn2 = document.createElement("button"); btn2.className = "end yt-uix-button yt-uix-tooltip" + (!ytcenter.watch7 ? " yt-uix-button-default" : " yt-uix-button-text"); btn2.setAttribute("onclick", ";return false;"); btn2.setAttribute("type", "button"); btn2.setAttribute("role", "button"); btn2.title = ytcenter.language.getLocale("BUTTON_DOWNlOAD2_TOOLTIP"); ytcenter.language.addLocaleElement(btn2, "BUTTON_DOWNlOAD2_TOOLTIP", "title"); var img = document.createElement("img"); img.className = "yt-uix-button-arrow"; img.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; img.setAttribute("alt", ""); img.style.marginLeft = "0px"; img.style.marginRight = "0px"; btn2.appendChild(img); var stream_groups = (function(){ var groups = (function(){ var obj = {}; for (var i = 0; i < ytcenter.video.format.length; i++) { obj[ytcenter.video.format[i].type] = { label: ytcenter.video.format[i].name, key: ytcenter.video.format[i].key, help: ytcenter.video.format[i].help }; } return obj; })(); var sorted = {}; for (var i = 0; i < ytcenter.video.streams.length; i++) { if (ytcenter.video.streams[i].type.indexOf("audio/mp4") !== 0 && (ytcenter.video.streams[i].size || ytcenter.video.streams[i].bitrate)) continue; if (ytcenter.video.streams[i].type) { var f = ytcenter.video.streams[i].type.split(";")[0]; if (groups.hasOwnProperty(f)) { if (!sorted[groups[f].label]) sorted[groups[f].label] = {streams: [], key: groups[f].key, help: groups[f].help}; sorted[groups[f].label].streams.push(ytcenter.video.streams[i]); } else { if (!sorted['UNKNOWN']) sorted['UNKNOWN'] = {streams: [], key: "unknown"}; sorted['UNKNOWN'].streams.push(ytcenter.video.streams[i]); } } else { if (!sorted['UNKNOWN']) sorted['UNKNOWN'] = {streams: [], key: "unknown"}; sorted['UNKNOWN'].streams.push(ytcenter.video.streams[i]); } } return sorted; })(); var menu = document.createElement("ul"); menu.className = "yt-uix-button-menu yt-uix-button-menu-default yt-uix-button-menu-external hid" + (ytcenter.settings.show3DInDownloadMenu ? "" : " ytcenter-menu-3d-hide"); menu.setAttribute("role", "menu"); menu.setAttribute("aria-haspopup", "true"); ytcenter.events.addEvent("ui-refresh", function(){ if (ytcenter.settings.show3DInDownloadMenu) { ytcenter.utils.removeClass(menu, "ytcenter-menu-3d-hide"); } else { ytcenter.utils.addClass(menu, "ytcenter-menu-3d-hide"); } }); for (var key in stream_groups) { if (stream_groups.hasOwnProperty(key)) { var title = document.createElement("li"); title.setAttribute("role", "menuitem"); title.style.color = "#666"; title.style.fontSize = "0.9166em"; title.style.paddingLeft = "9px"; if (key !== "UNKNOWN") { var __t = document.createTextNode(ytcenter.language.getLocale(key)); title.appendChild(__t); ytcenter.language.addLocaleElement(__t, key, "@textContent"); title.className = "ytcenter-downloadmenu-" + stream_groups[key].key; if (stream_groups[key].help) { var help = document.createElement("a"); help.setAttribute("href", stream_groups[key].help); help.setAttribute("target", "_blank"); help.setAttribute("style", "vertical-align: super; font-size: 10px"); help.appendChild(document.createTextNode('?')); var replace = { option: { toString: function() { return ytcenter.language.getLocale(key); } } }; help.setAttribute("title", ytcenter.utils.replaceTextAsString(ytcenter.language.getLocale("SETTINGS_HELP_ABOUT"), replace)); ytcenter.language.addLocaleElement(help, "SETTINGS_HELP_ABOUT", "title", replace); title.appendChild(help); } } else { title.className = "ytcenter-downloadmenu-unknown"; title.textContent = ytcenter.language.getLocale("UNKNOWN"); ytcenter.language.addLocaleElement(title, "UNKNOWN", "@textContent"); } //stream_groups[key] = stream_groups[key].streams; // Just lazy... menu.appendChild(title); for (var i = 0; i < stream_groups[key].streams.length; i++) { var is3D = (stream_groups[key].streams[i].stereo3d && stream_groups[key].streams[i].stereo3d == 1 ? true : false); var item = document.createElement("a"); if (!stream_groups[key].streams[i].url) { item.style.color = "#A7A7A7"; item.style.display = "block"; item.style.margin = "0"; item.style.padding = "6px 20px"; item.style.textDecoration = "none"; item.style.whiteSpace = "nowrap"; item.style.wordWrap = "normal"; } else { item.className = "yt-uix-button-menu-item"; item.setAttribute("target", "_blank"); item.setAttribute("download", ytcenter.video.getFilename(stream_groups[key].streams[i]) + ytcenter.video.getFilenameExtension(stream_groups[key].streams[i])); item.href = ytcenter.video.downloadLink(stream_groups[key].streams[i]); var downloadStreamListener = (function(_stream){ return function(e){ if (!ytcenter.settings.downloadAsLinks) { ytcenter.video.download(_stream.itag); e.preventDefault(); } }; })(stream_groups[key].streams[i]); ytcenter.utils.addEventListener(item, "click", downloadStreamListener, false); ytcenter.events.addEvent("ui-refresh", (function(__stream, item, _downloadStreamListener){ return function(){ item.href = ytcenter.video.downloadLink(__stream); item.setAttribute("download", ytcenter.video.getFilename(__stream) + ytcenter.video.getFilenameExtension(__stream)); }; })(stream_groups[key].streams[i], item, downloadStreamListener)); } var stream_name = { highres: ytcenter.language.getLocale("HIGHRES"), hd1440: ytcenter.language.getLocale("HD1440"), hd1080: ytcenter.language.getLocale("HD1080"), hd720: ytcenter.language.getLocale("HD720"), large: ytcenter.language.getLocale("LARGE"), medium: ytcenter.language.getLocale("MEDIUM"), small: ytcenter.language.getLocale("SMALL") }[stream_groups[key].streams[i].quality]; var _t = document.createElement("table"), _tb = document.createElement("tbody"), _tr = document.createElement("tr"), _td = document.createElement("td"), _td2 = document.createElement("td"); _t.style.width = "100%"; _t.style.border = "0"; _t.style.margin = "0"; _t.style.padding = "0"; if (stream_groups[key].streams[i].bitrate) { _td.textContent = Math.round(parseInt(stream_groups[key].streams[i].bitrate)/1000) + " Kbps"; } else { _td.textContent = stream_name + ", " + (stream_groups[key].streams[i].dimension ? stream_groups[key].streams[i].dimension.split("x")[1] : "") + "p (" + (stream_groups[key].streams[i].dimension ? stream_groups[key].streams[i].dimension : "") + ")"; _td2.textContent = (is3D ? " 3D" : ""); } _tr.appendChild(_td); _tr.appendChild(_td2); _tb.appendChild(_tr); _t.appendChild(_tb); item.appendChild(_t); ytcenter.events.addEvent("ui-refresh", (function(stream, _is3D, _td, _td2){ return function(){ var stream_name = { highres: ytcenter.language.getLocale("HIGHRES"), hd1440: ytcenter.language.getLocale("HD1440"), hd1080: ytcenter.language.getLocale("HD1080"), hd720: ytcenter.language.getLocale("HD720"), large: ytcenter.language.getLocale("LARGE"), medium: ytcenter.language.getLocale("MEDIUM"), small: ytcenter.language.getLocale("SMALL") }[stream.quality]; if (stream.bitrate) { _td.textContent = Math.round(parseInt(stream.bitrate)/1000) + " Kbps"; } else { _td.textContent = stream_name + ", " + (stream.dimension ? stream.dimension.split("x")[1] : "") + "p (" + (stream.dimension ? stream.dimension : "") + ")"; _td2.textContent = (_is3D ? " 3D" : ""); } }; })(stream_groups[key].streams[i], is3D, _td, _td2)); var li = document.createElement("li"); li.className = "ytcenter-downloadmenu-" + (stream_groups[key].key === "UNKNOWN" ? "unknown" : stream_groups[key].key) + (is3D ? " ytcenter-menu-item-3d" : ""); li.setAttribute("role", "menuitem"); li.appendChild(item); menu.appendChild(li); } } } var mp3title = document.createElement("li"); mp3title.className = (ytcenter.settings.mp3Services == '' ? "hid" : ""); if (ytcenter.settings.mp3Services === '') { mp3title.style.display = "none"; } mp3title.style.color = "#666"; mp3title.style.fontSize = "0.9166em"; mp3title.style.paddingLeft = "9px"; mp3title.textContent = ytcenter.language.getLocale("BUTTON_DOWNLOAD_MENU_MP3SERVICES"); ytcenter.language.addLocaleElement(mp3title, "BUTTON_DOWNLOAD_MENU_MP3SERVICES", "@textContent"); ytcenter.events.addEvent("ui-refresh", function(){ if (ytcenter.settings.mp3Services === '') { ytcenter.utils.addClass(mp3title, 'hid'); mp3title.style.display = "none"; } else { ytcenter.utils.removeClass(mp3title, 'hid'); mp3title.style.display = ""; } }); menu.appendChild(mp3title); var hasMP3Service = function(value){ var a = ytcenter.settings.mp3Services.split("&"); for (var i = 0; i < a.length; i++) { if (decodeURIComponent(a[i]) === value) { return true; } } return false; }; var removeNonExistentMP3Services = function(){ var newArr = []; var a = ytcenter.settings.mp3Services.split("&"); for (var i = 0; i < a.length; i++) { for (var j = 0; j < ytcenter.mp3services.length; j++) { if (ytcenter.mp3services[j].value === decodeURIComponent(a[i])) { newArr.push(a[i]); break; } } } ytcenter.settings.mp3Services = newArr.join("&"); }; removeNonExistentMP3Services(); for (var i = 0; i < ytcenter.mp3services.length; i++) { var li = document.createElement("li"); var item = document.createElement("a"); item.className = "yt-uix-button-menu-item"; li.setAttribute("role", "menuitem"); li.className = "ytcenter-downloadmenu-MP3" + (hasMP3Service(ytcenter.mp3services[i].value) ? "" : " hid"); if (!hasMP3Service(ytcenter.mp3services[i].value)) { li.style.display = "none"; } item.setAttribute("href", ytcenter.utils.replaceTextAsString(ytcenter.mp3services[i].value, { title: ytcenter.video.title, videoid: ytcenter.video.id, author: ytcenter.video.author, url: loc.href })); item.setAttribute("target", "_blank"); var mp3RedirectListener = (function(mp3){ return function(e){ if (!ytcenter.settings.downloadAsLinks) { ytcenter.redirect(mp3.value, true); e.preventDefault(); return false; } }; })(ytcenter.mp3services[i]); ytcenter.utils.addEventListener(item, "click", mp3RedirectListener, false); ytcenter.events.addEvent("ui-refresh", (function(mp3, li){ return function(){ var a = ytcenter.settings.mp3Services.split("&"); var f = false; for (var i = 0; i < a.length; i++) { if (decodeURIComponent(a[i]) === mp3.value) { f = true; break; } } if (f) { ytcenter.utils.removeClass(li, 'hid'); li.style.display = ""; } else { ytcenter.utils.addClass(li, 'hid'); li.style.display = "none"; } }; })(ytcenter.mp3services[i], li)); item.textContent = ytcenter.language.getLocale(ytcenter.mp3services[i].label); ytcenter.language.addLocaleElement(item, ytcenter.mp3services[i].label, "@textContent"); li.appendChild(item); menu.appendChild(li); } btn2.appendChild(menu); g.appendChild(btn2); ytcenter.placementsystem.addElement("ytcenter", "downloadgroup", g); } function $CreateSettingsUI() { var appbar = document.getElementById("appbar-settings-menu"), appSecondaryContainer = document.getElementById("appbar-secondary-container"), liSettings = document.createElement("li"), spanText = document.createElement("span"), textIconContainer = document.createElement("span"), textIcon = document.createElement("img"), text = null; if (ytcenter.feather) { var wrapper = document.getElementById("us"), aLink = document.createElement("a"), gearicon = document.createElement("img"); gearicon.src = ytcenter.icon.gear; gearicon.setAttribute("alt", ""); aLink.appendChild(gearicon); aLink.className = "ml"; aLink.setAttribute("href", "javascript:void(0);"); ytcenter.utils.addEventListener(aLink, "click", function(e){ if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); ytcenter.settingsPanelDialog.setVisibility(true); e && e.preventDefault && e.preventDefault(); return false; }, false); aLink.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); ytcenter.language.addLocaleElement(aLink, "BUTTON_SETTINGS_TITLE", "title"); wrapper.appendChild(aLink); } else if (appbar) { liSettings.setAttribute("id", "ytcenter-settings-toggler"); liSettings.setAttribute("role", "menuitem"); liSettings.className = "yt-uix-button-menu-new-section-separator"; spanText.className = "yt-uix-button-menu-item upload-menu-item"; ytcenter.utils.addEventListener(spanText, "click", function(){ if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); ytcenter.settingsPanelDialog.setVisibility(true); }, false); textIconContainer.className = "yt-valign icon-container"; textIcon.className = "upload-menu-account-settings-icon yt-valign-container"; textIcon.setAttribute("src", "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"); textIconContainer.appendChild(textIcon); text = document.createTextNode(ytcenter.language.getLocale("BUTTON_SETTINGS_LABEL")); ytcenter.language.addLocaleElement(text, "BUTTON_SETTINGS_LABEL", "@textContent"); spanText.appendChild(textIconContainer); spanText.appendChild(text); liSettings.appendChild(spanText); appbar.appendChild(liSettings); } else if (appSecondaryContainer) { var btn = document.createElement("button"), iconWrapper = document.createElement("span"), icon = document.createElement("img"); btn.className = "appbar-action-button flip yt-uix-button yt-uix-button-default yt-uix-button-size-default yt-uix-button-has-icon yt-uix-button-empty yt-uix-tooltip"; btn.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); ytcenter.language.addLocaleElement(btn, "BUTTON_SETTINGS_TITLE", "title"); btn.setAttribute("type", "button"); btn.setAttribute("role", "button"); btn.setAttribute("onclick", ";return false;"); ytcenter.utils.addEventListener(btn, "click", function(){ if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); ytcenter.settingsPanelDialog.setVisibility(true); }, false); iconWrapper.className = "yt-uix-button-icon-wrapper"; icon.className = "yt-uix-button-icon yt-uix-button-icon-appbar-settings"; icon.src = "https://s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"; icon.setAttribute("alt", ""); icon.setAttribute("title", ""); iconWrapper.appendChild(icon); btn.appendChild(iconWrapper); appSecondaryContainer.appendChild(btn); } else { var btn = document.createElement("button"); btn.id = "masthead-user-button"; if (document.getElementById("masthead-gaia-photo-expander")) { btn.style.marginTop = "3px"; } else if (document.getElementById("masthead-user-expander")) { btn.style.verticalAlign = "middle"; } btn.title = ytcenter.language.getLocale("BUTTON_SETTINGS_TITLE"); ytcenter.language.addLocaleElement(btn, "BUTTON_SETTINGS_TITLE", "title"); btn.setAttribute("type", "button"); btn.setAttribute("role", "button"); btn.setAttribute("onclick", ";return false;"); btn.className = "yt-uix-tooltip-reverse yt-uix-button " + (ytcenter.watch7 ? "yt-uix-button-text" : "yt-uix-button-text") + " yt-uix-tooltip"; var btnt = document.createElement("span"); btnt.className = "yt-uix-button-icon-wrapper"; btnt.style.margin = "0"; var gearicon = document.createElement("img"); gearicon.src = ytcenter.icon.gear; gearicon.setAttribute("alt", ""); var ytvt = document.createElement("span"); ytvt.className = "yt-valign-trick"; btnt.appendChild(gearicon); btnt.appendChild(ytvt); btn.appendChild(btnt); var ytuixbc = document.createElement("span"); ytuixbc.className = "yt-uix-button-content"; ytuixbc.textContent = " "; btn.appendChild(ytuixbc); ytcenter.utils.addEventListener(btn, "click", function(){ if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); ytcenter.settingsPanelDialog.setVisibility(true); }, false); if (document.getElementById("masthead-user")) { document.getElementById("masthead-user").appendChild(btn); } else if (document.getElementById("yt-masthead-user")) { document.getElementById("yt-masthead-user").appendChild(btn); } else if (document.getElementById("yt-masthead-signin")) { btn.style.margin = "0 10px"; document.getElementById("yt-masthead-signin").appendChild(btn); } else { con.error("Settings UI - Couldn't add settings button"); } } } function $CloneArray(arr) { var copy = []; for (var i = 0; i < arr.length; i++) { copy[i] = arr[i]; } return copy; } function $Clone(obj) { var copy; if (null == obj || typeof obj != "object") { return obj; } if (obj instanceof Date) { copy = new Date(); copy.setTime(obj.getTime()); return copy; } if (obj instanceof Array) { copy = []; for (var i = 0; i < obj.length; i++) { copy[i] = $Clone(obj[i]); } return copy; } if (obj instanceof Object) { copy = {}; for (var key in obj) { if (obj.hasOwnProperty(key)) { copy[key] = $Clone(obj[key]); } } return copy; } return null; } function $ArrayIndexOf(arr, obj) { for (var i = 0; i < arr.length; i++) { if (arr[i] === obj) return i; } return -1; } function $SlideRange(elm, handle, min, max, defaultValue) { function mousemove(e){ if (range.mouse.down) { e.preventDefault(); if (e && e.type.indexOf("touch") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { e = e.changedTouches[0]; } var pos = e.clientX - $AbsoluteOffset(range.elm)[0] - range.handle.offsetWidth/2; var max = range.elm.clientWidth - range.handle.offsetWidth; if (pos > max) { pos = max; } else if (pos < 0) { pos = 0; } range.handle.style.left = pos + "px"; for (var i = 0; i < range.listeners.length; i++) { if (range.listeners[i].e === 'valuechange') { var max = range.elm.clientWidth - range.handle.offsetWidth; var a = range.max - range.min; range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); } } } } function mousedownListener(e){ range.mouse.down = true; throttleFunc = ytcenter.utils.throttle(mousemove, 50); ytcenter.utils.addEventListener(document, "mousemove", throttleFunc, false); ytcenter.utils.addEventListener(document, "touchmove", throttleFunc, false); e.preventDefault(); } function mouseupListener(e){ if (range.mouse.down) { range.mouse.down = false; e.stopPropagation(); for (var i = 0; i < range.listeners.length; i++) { if (range.listeners[i].e === 'change') { var max = range.elm.clientWidth - range.handle.offsetWidth; var a = range.max - range.min; range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); } } if (throttleFunc) ytcenter.utils.removeEventListener(document, "mousemove", throttleFunc, false); if (throttleFunc) ytcenter.utils.removeEventListener(document, "touchmove", throttleFunc, false); e.preventDefault(); } } function clickListener(e) { var a; var pos = e.clientX - $AbsoluteOffset(range.elm)[0] - range.handle.offsetWidth/2; var max = range.elm.clientWidth - range.handle.offsetWidth; if (pos > max) { pos = max; } else if (pos < 0) { pos = 0; } range.handle.style.left = pos + "px"; for (var i = 0; i < range.listeners.length; i++) { if (range.listeners[i].e === 'valuechange') { max = range.elm.clientWidth - range.handle.offsetWidth; a = range.max - range.min; range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); } else if (range.listeners[i].e === 'change') { max = range.elm.clientWidth - range.handle.offsetWidth; a = range.max - range.min; range.listeners[i].c(parseFloat(range.handle.style.left)/max*a+range.min); } } e.preventDefault(); } var range = { elm: elm, handle: handle, min: (min ? min : 0), max: (max ? max : 100), defaultValue: (defaultValue ? defaultValue : min), mouse: { down: false }, listeners: [], width: 240, height: 15 }, throttleFunc = null; range.elm.style.marginTop = "-4px"; range.elm.style.width = range.width + "px"; range.elm.style.height = range.height + "px"; range.handle.style.width = range.height + "px"; range.handle.style.height = range.height + "px"; var returnKit = { addEventListener: (function(range){ return function(event, callback){ range.listeners.push({ e: event, c: callback }); }; })(range), getValue: (function(range){ return function(){ var max = parseInt(range.elm.style.width) - (range.height + 2); var a = range.max - range.min; return parseFloat(range.handle.style.left)/max*a+range.min || range.defaultValue; }; })(range), setValue: (function(range){ return function(val){ var max = parseInt(range.elm.style.width) - (range.height + 2); var pos = (val - range.min)/(range.max - range.min)*max; if (pos > max) { pos = max; } else if (pos < 0) { pos = 0; } range.handle.style.left = pos + "px"; if (val == 0) { return 0; } else { return returnKit.getValue(); } }; })(range) }; returnKit.setValue(range.defaultValue); ytcenter.utils.addEventListener(elm, "click", clickListener, false); /* Mouse */ ytcenter.utils.addEventListener(elm, "mousedown", mousedownListener, false); ytcenter.utils.addEventListener(document, "mouseup", mouseupListener, false); /* Touch */ ytcenter.utils.addEventListener(elm, "touchstart", mousedownListener, false); ytcenter.utils.addEventListener(document, "touchend", mouseupListener, false); return returnKit; } function $AbsoluteOffset(elm) { var pos = [elm.offsetLeft || 0, elm.offsetTop || 0]; if (elm.offsetParent) { var ao = $AbsoluteOffset(elm.offsetParent); pos[0] += ao[0]; pos[1] += ao[1]; } return pos; } /* END UTILS */ /* Classes */ function defineLockedProperty(obj, key, setter, getter) { if (typeof obj !== "object") obj = {}; if (ytcenter.utils.ie || typeof Object.defineProperty === "function") { 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) { 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 = undefined; var frozen = false; 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; }); } function PlayerConfig(configSetter, configGetter) { defineLockedProperty(this, "config", function(value){ configSetter(value); }, function(){ return configGetter(); }); } var console_debug = devbuild; // Disable this to stop YouTube Center 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.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; }()); 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_ = document.getElementById("logo-container").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; } document.getElementById("logo-container").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); } } }; ytcenter.spfPackages = function(originalPackages){ function parse(data) { if (ytcenter.utils.isArray(data)) { var i, type; for (i = 0; i < data.length; i++) { type = parseType(data[i]); addType(type, data[i]); } } else { if (data.type && !multipart) { multipart = true; parse(data.parts); } else { addType(parseType(data), data); } } } function addType(type, data) { var _types = type.split(","), i, index = packages.push(ytcenter.spfData(data)) - 1; for (i = 0; i < _types.length; i++) { if (!hasType(_types[i])) { types.push(_types[i]); } if (!pointer[_types[i]]) pointer[_types[i]] = []; pointer[_types[i]].push(index); } } function parseType(data) { var type = []; if ((data.swfcfg) || (data.html && data.html.content && data.html.content.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) || (data.html && data.html.player && data.html.player && data.html.player.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) || (data.html && data.html.content && data.html.content.indexOf("data-swf-config=\"") !== -1)) type.push("player"); if (data.attr && data.html && data.js) type.push("page"); if (data.css && data.js) type.push("header"); if (type.length === 0) { con.log("[SPF] Received unknown package!", type, data); return "unknown"; } return type.join(","); } function getPackage(type) { if (!pointer[type] || !packages[pointer[type][0]]) return null; return packages[pointer[type][0]].getData(); } function getData(type) { if (!pointer[type] || !packages[pointer[type][0]]) return null; return packages[pointer[type][0]]; } function getAvailableTypes() { return types; } function getOriginalPackages() { return originalPackages; } function getPackages(type) { var i, arr = []; if (type) { if (!pointer[type]) return null; for (i = 0; i < pointer[type].length; i++) { arr.push(packages[pointer[type][i]].getData()); } if (multipart) { var _o = ytcenter.utils.clone(originalPackages); _o.parts = arr; return _o; } else { return arr; } } else { for (i = 0; i < packages.length; i++) { arr.push(packages[i].getData()); } if (multipart) { var _o = ytcenter.utils.clone(originalPackages); _o.parts = arr; return _o; } else { if (arr.length === 1) return arr[0]; return arr; } } } function getTitle() { var i, title = null; for (i = 0; i < packages.length; i++) { title = packages[i].getTitle(); if (title) return title; } return title; } function setTitle(title) { var i; for (i = 0; i < packages.length; i++) { if (packages[i].getTitle()) packages[i].setTitle(title); } } function hasType(type) { var i; for (i = 0; i < types.length; i++) { if (types[i] === type) return true; } return false; } var types = [], pointer = {} /* { player: [2, 3], page: [3] } */, packages = [], multipart = false; parse(originalPackages); return { getData: getData, getAvailableTypes: getAvailableTypes, hasType: hasType, getPackages: getPackages, getOriginalPackages: getOriginalPackages, getTitle: getTitle, setTitle: setTitle }; }; ytcenter.spfData = function(originalPackage){ function parse(rawData) { parsePlayerConfig(rawData); } function parsePlayerConfigType(content) { content = content.split("<script>var ytplayer = ytplayer || {};ytplayer.config = ")[1]; content = content.split(";</script>")[0]; return JSON.parse(content); } function parsePlayerConfig(d) { if (!d) return; if (d.swfcfg) { playerConfig = d.swfcfg; } else if (d.html && d.html.content && d.html.content.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) { playerConfig = parsePlayerConfigType(d.html.content); } else if (d.html && d.html.player && d.html.player && d.html.player.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) { playerConfig = parsePlayerConfigType(d.html.player); } else if (d.html && d.html.content && d.html.content.indexOf("data-swf-config=\"") !== -1) { var a = d.html.content.split("data-swf-config=\""), i1, i2; if (a && a.length > 1) { a = a[1]; if (a.indexOf("\">") !== -1) { a = a.split("\">"); if (a && a.length > 1) { a = a[0]; } else { a = null; } } else { a = null; } } else { a = null; } if (a !== null) { playerConfig = JSON.parse(ytcenter.utils.decodeRawTag(a).replace(/&/g, "&").replace(/"/g, "\"")); } } } function injectPlayerConfig(content, config) { return ytcenter.utils.replaceContent(content, config, "<script>var ytplayer = ytplayer || {};ytplayer.config = ", ";</script>"); } function injectDataPlayerConfig(d, config) { if (d.swfcfg) { d.swfcfg = config; } else if (d.html && d.html.content && d.html.content.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) { d.html.content = injectPlayerConfig(d.html.content, config); } else if (d.html && d.html.player && d.html.player && d.html.player.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) { d.html.player = injectPlayerConfig(d.html.player, config); } else if (d.html && d.html.content && d.html.content.indexOf("data-swf-config=\"") !== -1) { var i1, i2; i1 = d.html.content.indexOf("data-swf-config=\"") + "data-swf-config=\"".length; i2 = d.html.content.indexOf("data-swf-config=\"") + d.html.content.split("data-swf-config=\"")[1].indexOf("\">") + "data-swf-config=\"".length; d.html.content = d.html.content.substring(0, i1) + ytcenter.utils.encodeRawTag(JSON.stringify(config).replace(/&/g, "&").replace(/"/g, """)) + d.html.content.substring(i2); } else { con.log("[SPF] Tried to set the player configuration for a package with no player config!"); } } function setHTML(id, value) { if (!data.html) data.html = {}; data.html[id] = value; } function getHTML(id) { if (!data.html) return null; return data.html[id]; } function setAttribute(id, attr, value) { try { if (!data.attr) data.attr = {}; if (typeof data.attr[id] === "undefined") data.attr[id] = {}; } catch (e) { con.error(e); var _tmp = {}; _tmp[id] = {}; data.attr = _tmp; } try { data.attr[id][attr] = value; } catch (e) { con.error(e); } } function getAttribute(id, attr) { if (!data) return null; if (!data.attr || !data.attr[id]) return null; return data.attr[id][attr]; } function setCSS(value) { data.css = value; } function getCSS() { return data.css; } function setJS(value) { data.js = value; } function getJS() { return data.js; } function getPlayerConfig() { return playerConfig; } function setPlayerConfig(config) { playerConfig = config; injectDataPlayerConfig(data, config); } function hasPlayerConfig() { return !!playerConfig; } function getTitle() { return data.title; } function setTitle(title) { data.title = title; } function getData() { return data; } function getOriginalPackage() { return originalPackage; } var data = ytcenter.utils.clone(originalPackage), playerConfig = null; parse(data); return { setHTML: setHTML, getHTML: getHTML, setAttribute: setAttribute, getAttribute: getAttribute, setCSS: setCSS, getCSS: getCSS, setJS: setJS, getJS: getJS, getPlayerConfig: getPlayerConfig, setPlayerConfig: setPlayerConfig, hasPlayerConfig: hasPlayerConfig, getData: getData, getOriginalPackage: getOriginalPackage, getTitle: getTitle, setTitle: setTitle }; }; /** * 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 setEnabled(enabled) { if (enabled) { !isEnabled() && uw && uw.spf && uw.spf.init && uw.spf.init(); } else { isEnabled() && uw && uw.spf && uw.spf.dispose && uw.spf.dispose(); } } 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 = [ "click", "cssbeforeunload", "cssunload", "done", "error", "history", "jsbeforeunload", "jsunload", "partdone", "partprocess", "process", "ready", "reload", "request" ]; var attachedEvents = { }; var events = [ ]; init(); return { addEventListener: addEventListener, removeEventListener: removeEventListener, setEnabled: setEnabled, isEnabled: isEnabled, init: init, dispose: dispose }; })(); 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; 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."); 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 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 */ 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 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 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.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.7"; ytcenter.revision = 156; 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: ".watch8 #watch7-views-info{bottom:initial!important;top:-6px!important}#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 #p,.ytcenter-lights-off #player-api,.ytcenter-lights-off #player-api-legacy,.ytcenter-lights-off #movie_player{position:relative;z-index:70!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:49}.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,.ytcenter-remove-ads-page.ytcenter-site-search .branded-page-v2-secondary-col{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}.ltr .watch-sidebar{margin-right:0!important}.rtl .watch-sidebar{margin-left:0!important}#movie_player{overflow:hidden!important}#player,#player-api,#player-api-legacy,#movie_player,#movie_player *:focus{outline:0!important}.watch-playlist-collapsed #watch7-playlist-tray-container{height:0!important;top:0!important}.ltr .watch-playlist-collapsed #watch7-playlist-tray-container{left:auto!important}.rtl .watch-playlist-collapsed #watch7-playlist-tray-container{right:auto!important}.ytcenter-site-center #page,.ytcenter-site-center #yt-masthead,.ytcenter-site-center #ad_creative_1,.ytcenter-site-center #footer,.ytcenter-site-center #masthead_child_div,.ytcenter-site-center #masthead-expanded-lists-container,.ytcenter-site-center #baseDiv,.ytcenter-site-center.no-sidebar #alerts,.ytcenter-site-center.no-sidebar #ticker .ytg-wide,.ytcenter-site-center.no-sidebar #masthead-subnav,#watch7-sidebar,.watch7-sidebar,.ytcenter-site-watch.ytcenter-resize-disaligned #player,.ytcenter-site-watch.ytcenter-resize-aligned #player{-moz-transition:none!important;-ms-transition:none!important;-o-transition:none!important;-webkit-transition:none!important;transition:none!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}.ltr.ytcenter-site-watch.ytcenter-site-center #page,.ltr.ytcenter-site-watch.ytcenter-site-center #player,.ltr.ytcenter-site-watch.ytcenter-site-center #player-legacy,.ltr.ytcenter-site-watch.ytcenter-site-center #content,.ltr.ytcenter-site-watch.site-center-aligned #page,.ltr.ytcenter-site-watch.site-center-aligned #player,.ltr.ytcenter-site-watch.site-center-aligned #player-legacy,.ltr.ytcenter-site-watch.site-center-aligned #content,.ltr.ytcenter-site-watch.ytcenter-resize-disaligned.ytcenter-site-center #player,.ltr.ytcenter-site-watch.ytcenter-resize-disaligned.ytcenter-site-center #player-legacy,.ltr.ytcenter-site-watch.ytcenter-resize-algined.ytcenter-site-center #player,.ltr.ytcenter-site-watch.ytcenter-resize-algined.ytcenter-site-center #player-legacy{left:auto!important;margin-left:auto!important;margin-right:auto!important}.rtl.ytcenter-site-watch.ytcenter-site-center #page,.rtl.ytcenter-site-watch.ytcenter-site-center #player,.rtl.ytcenter-site-watch.ytcenter-site-center #player-legacy,.rtl.ytcenter-site-watch.ytcenter-site-center #content,.rtl.ytcenter-site-watch.site-center-aligned #page,.rtl.ytcenter-site-watch.site-center-aligned #player,.rtl.ytcenter-site-watch.site-center-aligned #player-legacy,.rtl.ytcenter-site-watch.site-center-aligned #content,.rtl.ytcenter-site-watch.ytcenter-resize-disaligned.ytcenter-site-center #player,.rtl.ytcenter-site-watch.ytcenter-resize-disaligned.ytcenter-site-center #player-legacy,.rtl.ytcenter-site-watch.ytcenter-resize-algined.ytcenter-site-center #player,.rtl.ytcenter-site-watch.ytcenter-resize-algined.ytcenter-site-center #player-legacy{right:auto!important;margin-left:auto!important;margin-right:auto!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{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{display:block!important;opacity:1!important;filter:alpha(opacity=100)!important}.ytcenter-thumbnail-timecode-visible-show_hover a: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}.flex-width-enabled .lohp-large-shelf-container{width:371px!important}.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}", resize: ".watch-wide #watch7-sidebar,.watch-wide #watch7-preview{top:0!important}#watch7-sidebar{margin-top:0!important}", topbar: ".ytcenter-exp-topbar-static #masthead-positioner{position:relative!important;top:0!important}.ytcenter-lights-off #masthead-positioner{position:static!important;top:0!important}.ytcenter-lights-off #masthead-positioner-height-offset,.ytcenter-exp-topbar-static #masthead-positioner-height-offset{display:none!important}.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}}.ytcenter-player-darkside-bg #player{width:100%!important;margin-left:0!important;margin-right:0!important;background-color:#1b1b1b}.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}.ytcenter-branding-remove-background.site-as-giant-card #watch7-sidebar{background-color:#fff!important}.ytcenter-branding-remove-background.site-as-giant-card .watch-wide #watch7-sidebar{background-color:transparent!important}.site-center-aligned #content #yt-admin{padding:0!important}", flags: ".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-button-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: ".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-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.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;margin-bottom:20px;vertical-align:top}.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: "#player-api{position:relative}body.ytcenter-scrolled-top{overflow:hidden}.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{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}.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}.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-non-resize #player.watch-medium #theater-background{height:510px}body.ytcenter-player-darkside-bg.ytcenter-non-resize #player.watch-large #theater-background{height:750px}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')}", 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"); /*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.removeClass(document.body, "ytcenter-scrolled-top-player-pre"); uw.setTimeout(function(){ inTransition = false; }, 500); } } 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; } } 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); } } } function onTransitionEndListener() { if (activated) { enterComplete(); } else { exitComplete(); } } function scroll(e, delta, deltaX, deltaY) { if (!enabled || inTransition) 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(); } } else if (scrollUpExit) { //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(); } } 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 = { /* 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: "http://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: "http://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: "http://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) { 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.filters = {}; exports.filters.repeat = function(condition, obj){ return (new RegExp("(.)\\1{" + parseInt(condition.amount, 10) + ",}")).test(obj.contentElement.textContent); }; exports.filters.biggerThan = function(condition, obj){ var len = obj.contentElement.textContent.length; if (len < parseInt(condition.length, 10)) return true; return false; }; exports.filters.smallerThan = function(condition, obj){ var len = obj.contentElement.textContent.length; if (len > parseInt(condition.length, 10)) return true; return false; }; exports.filters.equals = function(condition, obj){ var len = obj.contentElement.textContent.length; if (len === parseInt(condition.length, 10)) return true; return false; }; exports.filters.text = function(condition, obj){ var regex = new RegExp(ytcenter.utils.replaceTextToText(condition.regex, { "${username}": ytcenter.utils.escapeRegExp(obj.username), "${textContent}": ytcenter.utils.escapeRegExp(obj.textContent), "${isReply}": ytcenter.utils.escapeRegExp(obj.isReply ? "1" : "0") })); return regex.test(obj.contentElement.textContent); }; exports.filters.links = function(condition, obj){ var regex, regexString = ytcenter.utils.replaceTextToText(condition.regex, { "${username}": ytcenter.utils.escapeRegExp(obj.username), "${textContent}": ytcenter.utils.escapeRegExp(obj.textContent), "${isReply}": ytcenter.utils.escapeRegExp(obj.isReply ? "1" : "0") }), attr = condition.attr || "href", links = obj.contentElement.getElementsByTagName("a"), i; for (i = 0; i < links.length; i++) { regex = new RegExp(ytcenter.utils.replaceTextToText(regexString, { "${linkContent}": links[i].textContent })); if (ytcenter.utils.hasClass(links[i], "ot-anchor") && regex.test(links[i][attr])) return true; } return false; }; exports.filters.profilelinks = function(condition, obj){ var regex, regexString = ytcenter.utils.replaceTextToText(condition.regex, { "${username}": ytcenter.utils.escapeRegExp(obj.username), "${textContent}": ytcenter.utils.escapeRegExp(obj.textContent), "${isReply}": ytcenter.utils.escapeRegExp(obj.isReply ? "1" : "0") }), attr = condition.attr || "href", links = obj.contentElement.getElementsByTagName("a"), i; for (i = 0; i < links.length; i++) { regex = new RegExp(ytcenter.utils.replaceTextToText(regexString, { "${linkContent}": links[i].textContent })); if (ytcenter.utils.hasClass(links[i], "proflink") && regex.test(links[i][attr])) return true; } return false; }; exports.filters.hashlinks = function(condition, obj){ var regex, regexString = ytcenter.utils.replaceTextToText(condition.regex, { "${username}": ytcenter.utils.escapeRegExp(obj.username), "${textContent}": ytcenter.utils.escapeRegExp(obj.textContent), "${isReply}": ytcenter.utils.escapeRegExp(obj.isReply ? "1" : "0") }), attr = condition.attr || "href", links = obj.contentElement.getElementsByTagName("a"), i; for (i = 0; i < links.length; i++) { regex = new RegExp(ytcenter.utils.replaceTextToText(regexString, { "${linkContent}": links[i].textContent })); if (ytcenter.utils.hasClass(links[i], "ot-hashtag") && regex.test(links[i][attr])) return true; } return false; }; exports.filters.username = function(condition, obj){ var regex = new RegExp(ytcenter.utils.replaceTextToText(condition.regex, { "${username}": ytcenter.utils.escapeRegExp(obj.username), "${textContent}": ytcenter.utils.escapeRegExp(obj.textContent), "${isReply}": ytcenter.utils.escapeRegExp(obj.isReply ? "1" : "0") })), img = obj.wrapper.getElementsByTagName("img")[0]; if (regex.test(img.getAttribute("title"))) return true; return false; }; exports.testFilters = function(list, obj){ var i; for (i = 0; i < list.length; i++) { if (list[i].type in exports.filters) { if (exports.filters[list[i].type](list[i], obj)) return true; } } return false; }; exports.__commentInfoIdNext = 0; exports.getCommentObjectByWrapper = function(wrapper){ var i; for (i = 0; i < exports.comments.length; i++) { if (exports.comments[i].wrapper === wrapper) return exports.comments[i]; } return null; }; exports.getCommentObject = function(contentElement, reshared){ var commentInfo = {}, tmp; commentInfo.isShared = (typeof reshared === "boolean" ? reshared : false); if (!contentElement) { con.error("[CommentsPlus:getCommentObject] contentElement is undefined!"); return commentInfo; } commentInfo.inDOM = true; commentInfo.contentElement = contentElement; commentInfo.textContent = contentElement.textContent; commentInfo.shared = commentInfo.textContent === ""; commentInfo.children = ytcenter.utils.toArray(contentElement.childNodes); // We don't want the array to change commentInfo.isReply = !commentInfo.isShared && contentElement && contentElement.parentNode && contentElement.parentNode.className.indexOf("Pm") === -1; commentInfo.isOrignalSharedReference = !commentInfo.isShared && contentElement && contentElement.parentNode && contentElement.parentNode.parentNode && contentElement.parentNode.parentNode.parentNode && contentElement.parentNode.parentNode.parentNode.parentNode && contentElement.parentNode.parentNode.parentNode.parentNode.className.indexOf("dga") !== -1; if (commentInfo.isReply) { commentInfo.wrapper = contentElement.parentNode.parentNode.parentNode; commentInfo.parentId = exports.getCommentObjectByWrapper(commentInfo.wrapper.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode.firstChild).id; } else if (commentInfo.isOrignalSharedReference) { try { exports.addCommentObject(exports.getCommentObject(contentElement, true)); } catch (e) { con.error(e); } commentInfo.wrapper = contentElement.parentNode.parentNode.parentNode.parentNode; var parent = exports.getCommentObjectByWrapper(commentInfo.wrapper.parentNode.parentNode); commentInfo.parentId = (parent !== null ? parent.id : null); } else { if (commentInfo.isShared) { commentInfo.wrapper = contentElement.parentNode.parentNode.parentNode.parentNode.parentNode.parentNode; } else { commentInfo.wrapper = contentElement.parentNode.parentNode.parentNode.parentNode.parentNode; } commentInfo.parentId = -1; } if (commentInfo.isOrignalSharedReference) { commentInfo.username = commentInfo.wrapper.children[1].textContent; } else { commentInfo.username = commentInfo.wrapper.getElementsByTagName("img")[0].getAttribute("title"); } commentInfo.profileRedirectURL = commentInfo.wrapper.getElementsByTagName("img")[0].parentNode.href; if (loc.href.indexOf("https://") === 0) { // Profile Redirect URL has to be a secure connection if (commentInfo.profileRedirectURL.indexOf("http://") === 0) { commentInfo.profileRedirectURL = commentInfo.profileRedirectURL.replace(/http\:\/\//, "https://"); } } else { // Profile Redirect URL has to be an unsecure connection if (commentInfo.profileRedirectURL.indexOf("https://") === 0) { commentInfo.profileRedirectURL = commentInfo.profileRedirectURL.replace(/https\:\/\//, "http://"); } } if (commentInfo.profileRedirectURL.indexOf("youtube.com/profile_redirector/") !== -1) { commentInfo.profileRedirectId = commentInfo.profileRedirectURL.split("youtube.com/profile_redirector/")[1]; commentInfo.channelRedirectId = null; commentInfo.googlePlusRedirectId = null; } else if (commentInfo.profileRedirectURL.indexOf("youtube.com/channel/") !== -1) { commentInfo.channelRedirectId = commentInfo.profileRedirectURL.split("youtube.com/channel/")[1]; commentInfo.profileRedirectId = null; commentInfo.googlePlusRedirectId = null; } else if (commentInfo.profileRedirectURL.indexOf("youtube.com/user/") !== -1) { commentInfo.channelRedirectId = commentInfo.profileRedirectURL.split("youtube.com/user/")[1]; commentInfo.profileRedirectId = null; commentInfo.googlePlusRedirectId = null; } else if (commentInfo.profileRedirectURL.indexOf("apis.google.com/u/") !== -1) { var s = commentInfo.profileRedirectURL.split("/"); commentInfo.googlePlusRedirectId = s[s.length - 1]; commentInfo.channelRedirectId = null; commentInfo.profileRedirectId = null; } else { commentInfo.profileRedirectId = null; commentInfo.channelRedirectId = null; commentInfo.googlePlusRedirectId = null; } if (commentInfo.isReply) { commentInfo.headerElement = commentInfo.wrapper.getElementsByClassName("fR")[0]; } else if (commentInfo.isOrignalSharedReference) { commentInfo.headerElement = commentInfo.wrapper; } else { commentInfo.headerElement = commentInfo.wrapper.getElementsByClassName("Mpa")[0]; } if (!commentInfo.headerElement) { con.error("[Comment Info] headerElement is undefined"); } if (commentInfo.isReply || commentInfo.isOrignalSharedReference) { commentInfo.headerUserDataElement = commentInfo.headerElement; } else { commentInfo.headerUserDataElement = commentInfo.headerElement.parentNode; } if (commentInfo.isReply) { commentInfo.viaGooglePlus = commentInfo.headerElement && commentInfo.headerElement.children && commentInfo.headerElement.children.length === 3 ? false : true; } else if (commentInfo.isOrignalSharedReference) { commentInfo.viaGooglePlus = true; } else { commentInfo.viaGooglePlus = commentInfo.headerElement && commentInfo.headerElement.children && commentInfo.headerElement.children.length === 1 ? false : true; } commentInfo.country = ytcenter.cache.getItem("profile_country", commentInfo.profileRedirectId || commentInfo.channelRedirectId); if (commentInfo.country) commentInfo.country = commentInfo.country.data; else commentInfo.country = null; commentInfo.flagAdded = false; return commentInfo; }; 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].isOrignalSharedReference === commentObject.isOrignalSharedReference && exports.comments[i].isShared === commentObject.isShared && (exports.comments[i].contentElement === commentObject.contentElement || exports.comments[i].wrapper === commentObject.wrapper)) 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 a = document.getElementsByClassName("Ct"), i; for (i = 0; i < a.length; i++) { try { exports.addCommentObject(exports.getCommentObject(a[i])); } catch (e) { con.error(e); } } }; exports.filter = function(){ var i, obj, blockedElement; for (i = 0; i < exports.comments.length; i++) { if (ytcenter.utils.hasClass(exports.comments[i].contentElement, "ytcenter-comments-loaded")) continue; exports.comments[i].contentElement.className += " ytcenter-comments-loaded"; obj = exports.comments[i]; if (exports.testFilters(ytcenter.settings.commentsPlusWhitelist, obj)) continue; /* Blacklist */ if (exports.testFilters(ytcenter.settings.commentsPlusBlacklist, obj)) { blockedElement = document.createElement("div"); blockedElement.textContent = "Comment Blocked by YouTube Center!"; // This is only temporary /*blockedElement.addEventListener("click", (function(obj, blockedElement, wrap){ function blockedElementListener(){ ytcenter.utils.removeClass(wrap, "ytcenter-comments-blocked"); blockedElement.parentNode.removeChild(blockedElement); blockedElement.removeEventListener("click", blockedElementListener, false); } return blockedElementListener; })(obj, blockedElement, obj.contentElement.parentNode.parentNode), false);*/ obj.contentElement.parentNode.parentNode.className += " ytcenter-comments-blocked"; obj.contentElement.parentNode.parentNode.insertBefore(blockedElement, obj.contentElement.parentNode); if (obj.wrapper) { obj.wrapper.lastChild.style.display = "none"; } } } }; exports.commentDuplicates = function(){ var i, j, duplicates, msg; for (i = 0; i < exports.comments.length; i++) { if (typeof exports.comments[i].duplicateId === "number" || !exports.comments[i].inDOM) continue; if (!ytcenter.utils.contains(document, exports.comments[i].wrapper)) { exports.comments[i].inDOM = false; continue; } duplicates = 0; for (j = 0; j < exports.comments.length; j++) { if (i === j || exports.comments[j].duplicateId === "number" || exports.comments[j].duplicates || !exports.comments[j].inDOM) continue; if (!ytcenter.utils.contains(document, exports.comments[j].wrapper)) { exports.comments[j].inDOM = false; continue; } if (exports.comments[i].username === exports.comments[j].username && exports.comments[i].textContent === exports.comments[j].textContent) { duplicates += 1; exports.comments[j].duplicateId = i; exports.comments[j].wrapper.style.display = "none"; } } if (duplicates > 0) { exports.comments[i].duplicates = duplicates; } } }; exports.completeFlag = function(comment, country){ var countryContainer = document.createElement("span"), metadata = comment.headerUserDataElement, countryName = ytcenter.language.getLocale("COUNTRY_ISO3166-1_CODES_" + country.toUpperCase()); comment && comment.unloadLoadButton && comment.unloadLoadButton(); countryContainer.className = "country"; if (ytcenter.settings.commentCountryShowFlag && 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()]; if (ytcenter.settings.commentCountryUseNames) { 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.commentCountryUseNames) { 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; } } if (ytcenter.settings.commentCountryPosition === "before_username") { countryContainer.style.marginRight = "10px"; if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.children[1]); } else { metadata.insertBefore(countryContainer, metadata.children[0]); } } else if (ytcenter.settings.commentCountryPosition === "after_username") { if (comment.isOrignalSharedReference) { countryContainer.style.marginLeft = "4px"; } else if (!comment.isReply) { countryContainer.style.marginLeft = "10px"; } else { countryContainer.style.marginRight = "8px"; } if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.childNodes[2]); } else { metadata.insertBefore(countryContainer, metadata.children[1]); } } else if (ytcenter.settings.commentCountryPosition === "last") { countryContainer.style.marginLeft = "10px"; if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.lastChild); } else if (!comment.isReply) { if (metadata.children.length > 2) { metadata.insertBefore(countryContainer, metadata.children[2]); } else { metadata.appendChild(countryContainer); } } else { if (metadata.children.length > 3) { metadata.insertBefore(countryContainer, metadata.children[3]); } else { metadata.appendChild(countryContainer); } } } }; exports.addLoadButton = function(comment){ function onLanguageRefresh(){ btn.element.setAttribute("alt", ytcenter.language.getLocale(btn_text)); btn.element.setAttribute("title", ytcenter.language.getLocale(btn_text)); btn.element.setAttribute("data-tooltip-text", ytcenter.language.getLocale(btn_text)); } var countryContainer = document.createElement("span"), metadata = comment.headerUserDataElement, 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) { btn_text = "COMMENTS_COUNTRY_BUTTON_LOAD_LOADING"; onLanguageRefresh(); btn.element.className += " ytcenter-flag-button-loading"; btn.setEnabled(false); 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); if (ytcenter.settings.commentCountryPosition === "before_username") { countryContainer.style.marginRight = "10px"; if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.children[1]); } else { metadata.insertBefore(countryContainer, metadata.children[0]); } } else if (ytcenter.settings.commentCountryPosition === "after_username") { if (comment.isOrignalSharedReference) { countryContainer.style.marginLeft = "4px"; } else if (!comment.isReply) { countryContainer.style.marginLeft = "10px"; } else { countryContainer.style.marginRight = "8px"; } if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.childNodes[2]); } else { metadata.insertBefore(countryContainer, metadata.children[1]); } } else if (ytcenter.settings.commentCountryPosition === "last") { countryContainer.style.marginLeft = "10px"; if (comment.isOrignalSharedReference) { metadata.insertBefore(countryContainer, metadata.lastChild); } else if (!comment.isReply) { if (metadata.children.length > 2) { metadata.insertBefore(countryContainer, metadata.children[2]); } else { metadata.appendChild(countryContainer); } } else { if (metadata.children.length > 3) { metadata.insertBefore(countryContainer, metadata.children[3]); } else { metadata.appendChild(countryContainer); } } } }; exports.handleFlagWorker = function(comment){ ytcenter.jobs.createWorker(comment.profileRedirectId || comment.channelRedirectId || comment.googlePlusRedirectId, function(args){ try { if (comment.profileRedirectId || comment.googlePlusRedirectId) { ytcenter.getGooglePlusUserData(comment.profileRedirectId || comment.googlePlusRedirectId, function(data){ if (data && data.entry && data.entry.yt$location && data.entry.yt$location.$t) { comment.country = data.entry.yt$location.$t; } else { comment && comment.unloadLoadButton && comment.unloadLoadButton(); con.error("[Comment Country] Unknown Location", data); } args.complete(comment.country || null); }); } else if (comment.channelRedirectId) { ytcenter.getUserData(comment.channelRedirectId, function(data){ if (data && data.entry && data.entry.yt$location && data.entry.yt$location.$t) { comment.country = data.entry.yt$location.$t; } else { comment && comment.unloadLoadButton && comment.unloadLoadButton(); con.error("[Comment Country] Unknown Location", data); } args.complete(comment.country || null); }); } } catch (e) { comment && comment.unloadLoadButton && comment.unloadLoadButton(); con.error(e); args.complete(null); } }, function(data){ if (!data) return; if (comment.profileRedirectId || comment.channelRedirectId) { ytcenter.cache.putItem("profile_country", comment.profileRedirectId || comment.channelRedirectId, 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.wrapper, "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.filter(); exports.commentDuplicates();*/ exports.addFlags(); }; exports.setupObserver = function(){ try { observer = ytcenter.mutation.observe(document.body, { 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(data){ var country = null; if (data && data.entry && data.entry.yt$location && data.entry.yt$location.$t) { country = data.entry.yt$location.$t; } else { con.error("[Comment Country] Unknown Location", data); } 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]; } else { 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){ ytcenter.utils.xhr({ url: "https://gdata.youtube.com/feeds/api/users/" + userId + "?alt=json", method: "GET", onload: function(r){ var data = null; try { data = JSON.parse(r.responseText); } catch (e) { con.error("[Comments getUserData] Couldn't parse data from https://gdata.youtube.com/feeds/api/users/" + userId + "?alt=json"); con.error(e); } callback(data); }, onerror: function(){ con.error("[Comments getUserData] Couldn't fetch data from https://gdata.youtube.com/feeds/api/users/" + userId + "?alt=json"); 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: "http://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 http://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 http://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\/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\/embed\//) || !!url.match(/^http(s)?:\/\/(www\.)?youtube\.com\/watch_popup\?\//)) { 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)\//)) { 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 getVideoThumbs() { 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])) continue; var data = handleVideoThumbs(arr[i], arr[i].parentNode); if (data) videos.push(data); } return videos; } function loadVideoConfig(item, callback) { if (item.stream && item.storyboard) { callback(item.stream, item.storyboard); } else { var spflink = true, url = "//www.youtube.com/watch?v=" + item.id + (spflink ? "&spf=navigate" : ""); if (loc.href.indexOf("https://") === 0) { url = "https:" + url; } else { url = "http:" + url; } ytcenter.utils.xhr({ url: url, method: "GET", onload: function(r){ var cfg = null; var errorType = "unknown"; try { try { if (spflink) { var parts = JSON.parse(r.responseText); 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 { cfg = r.responseText.split("<script>var ytplayer = ytplayer || {};ytplayer.config = ")[1].split(";</script>")[0]; cfg = JSON.parse(cfg); } } catch (e) { con.error(e); if (r.responseText.indexOf("flashvars=\"") !== -1) { var a = r.responseText.split("flashvars=\"")[1].split("\"")[0].replace(/&/g, "&").replace(/"/g, "\"").split("&"), i, b; cfg = {args: {}}; for (i = 0; i < a.length; i++) { b = a[i].split("="); cfg.args[decodeURIComponent(b[0])] = decodeURIComponent(b[1]); } } else if (r.responseText.indexOf("new yt.player.Application('p', {") !== -1) { cfg = {}; cfg.args = r.responseText.split("new yt.player.Application('p', ")[1].split(");var fbetatoken")[0]; cfg.args = JSON.parse(cfg.args); } } item.stream = ytcenter.player.getBestStream(ytcenter.parseStreams(cfg.args), (ytcenter.settings.videoThumbnailQualitySeparated ? (ytcenter.settings.dashPlayback ? 1 : 0) : -1)); if (!item.stream) { if (cfg && cfg.args && cfg.args.ypc_module && cfg.args.ypc_vid) { item.stream = { quality: "ondemand" }; } } if (cfg && cfg.args) { item.storyboard = cfg.args.storyboard_spec || cfg.args.live_storyboard_spec; } try { delete item.stream.fallback_host; delete item.stream.sig; delete item.stream.flashVersion; delete item.stream.url; } catch (e) { con.error(e); } try { if (isInCache(item)) { updateItemInCache(item); } else { addNewDataToCache(item); } } catch (e) { con.error(e); } if (item.stream) { callback(item.stream, item.storyboard); } else { callback("error", null, "Error!"); } } catch (e) { var msg = ""; if (e === "unavailable") { msg = "Video Unavailable!"; } else { if (r.responseText.indexOf("Too many") !== -1) { msg = "Too many requests!"; } else { msg = "Error!"; con.error(e); con.error(cfg); try { con.error(JSON.parse(r.responseText)); } catch (e) { con.error(r.responseText); } } } con.error("[VideoThumbnail Quality] IO Error => " + msg); callback("error", null, msg); } }, onerror: function(){ var msg = "Connection failed!"; con.error("[VideoThumbnail Quality] IO Error => " + msg); callback("error", null, msg); } }); } } function loadVideoData(item, callback) { if (item.likes && item.dislikes) { callback(item.likes, item.dislikes); } else if (item.id) { ytcenter.utils.xhr({ url: "https://gdata.youtube.com/feeds/api/videos/" + item.id + "?v=2&alt=json", method: "GET", onload: function(r){ try { if (!r.responseText) throw "unavailable"; var videoData = JSON.parse(r.responseText).entry, ratings = videoData.yt$rating; item.likes = parseInt(ratings ? ratings.numLikes : 0); item.dislikes = parseInt(ratings ? ratings.numDislikes : 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 { 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("img"), dislikeIcon = document.createElement("img"); 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 = ""; // icon-watch-stats-like likeIcon.setAttribute("alt", "Like"); likeIcon.src = ytcenter.icon.smallThumbsUpWhite; likeIcon.style.position = "relative"; likeIcon.style.marginRight = "2px"; likeIcon.style.marginTop = "4px"; likeIcon.style.top = "-2px"; likeIcon.style.verticalAlign = "middle"; dislikeIcon.className = ""; // icon-watch-stats-dislike dislikeIcon.setAttribute("alt", "Dislike"); dislikeIcon.src = ytcenter.icon.smallThumbsDownWhite; 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); } } 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 = "#000"; 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; } 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) { 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[0]); } 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 processItem(item) { if (!ytcenter.settings.videoThumbnailRatingsCount && !ytcenter.settings.videoThumbnailRatingsBar) return; if (ytcenter.settings.videoThumbnailRatingsBarDownloadAt === "hover_thumbnail" && ytcenter.settings.videoThumbnailRatingsCountDownloadAt === "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 (ytcenter.settings.videoThumbnailRatingsCount) { appendRatingCount(item, likes, dislikes); } if (ytcenter.settings.videoThumbnailRatingsBar) { appendRatingBar(item, likes, dislikes); } }); }; })(), false); } else { if (ytcenter.settings.videoThumbnailRatingsBarDownloadAt === "page_start" || ytcenter.settings.videoThumbnailRatingsCountDownloadAt === "page_start") { loadVideoData(item, function(likes, dislikes){ if (ytcenter.settings.videoThumbnailRatingsCount) { appendRatingCount(item, likes, dislikes); } if (ytcenter.settings.videoThumbnailRatingsBar) { appendRatingBar(item, likes, dislikes); } }); } else { if (ytcenter.settings.videoThumbnailRatingsBarDownloadAt === "scroll_into_view" && ytcenter.settings.videoThumbnailRatingsBar) { ytcenter.domEvents.addEvent(item.wrapper, "enterview", function(){ loadVideoData(item, function(likes, dislikes){ appendRatingBar(item, likes, dislikes); }); }, true); } else if (ytcenter.settings.videoThumbnailRatingsBarDownloadAt === "hover_thumbnail" && ytcenter.settings.videoThumbnailRatingsBar) { ytcenter.utils.addEventListener(item.wrapper, "mouseover", (function(){ var added = false; return function(){ if (added) return; added = true; loadVideoData(item, function(likes, dislikes){ appendRatingBar(item, likes, dislikes); }); }; })(), false); } else if (ytcenter.settings.videoThumbnailRatingsBar) { loadVideoData(item, function(likes, dislikes){ appendRatingBar(item, likes, dislikes); }); } if (ytcenter.settings.videoThumbnailRatingsCountDownloadAt === "scroll_into_view" && ytcenter.settings.videoThumbnailRatingsCount) { ytcenter.domEvents.addEvent(item.wrapper, "enterview", function(){ loadVideoData(item, function(likes, dislikes){ appendRatingCount(item, likes, dislikes); }); }, true); } else if (ytcenter.settings.videoThumbnailRatingsCountDownloadAt === "hover_thumbnail" && ytcenter.settings.videoThumbnailRatingsCount) { ytcenter.utils.addEventListener(item.wrapper, "mouseover", (function(){ var added = false; return function(){ if (added) return; added = true; loadVideoData(item, function(likes, dislikes){ appendRatingCount(item, likes, dislikes); }); }; })(), false); } else if (ytcenter.settings.videoThumbnailRatingsCount) { loadVideoData(item, function(likes, dislikes){ appendRatingCount(item, likes, dislikes); }); } } } } function compareDifference(newData, oldData) { var a = false; var arr = []; for (var i = 0, len = newData.length; i < len; i++) { a = false; for (var j = 0, lenj = oldData.length; j < lenj; j++) { if (oldData[j].wrapper === newData[i].wrapper) { a = true; break; } } if (!a) { 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; 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"); }*/ processItem(vt[i]); processItemHeavyLoad(vt[i]); if (loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) { updateWatchedClass(vt[i]); } if ((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(); 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]); processItem(videoThumbs[i]); processItemHeavyLoad(videoThumbs[i]); if (loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) { updateWatchedClass(videoThumbs[i]); } if ((loc.pathname === "/" || loc.pathname === "/results" || loc.pathname.indexOf("/feed/") === 0) && ytcenter.settings.watchedVideosIndicator) { updateWatchedMessage(videoThumbs[i]); } } exports.setupObserver(); } catch (e) { con.error(e); } }; return exports; })(); ytcenter.getDebug = function(){ var debugText = "{}", dbg = {}, a; 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 = ytcenter.player.getReference().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 { var tests = ["getAvailablePlaybackRates", "getAvailableQualityLevels", "getCurrentTime", "getDebugText", "getDuration", "getPlaybackQuality", "getPlaybackRate", "getPlayerState", "getPlayerType", "getVolume", "isMuted", "isReady"]; dbg.player_test = {}; for (var i = 0; i < tests.length; i++) { if (ytcenter.player.getReference().api[tests[i]]) dbg.player_test[tests[i]] = ytcenter.player.getReference().api[tests[i]](); } } catch (e) { dbg.player_test_error = e.message; } dbg.console = _console; debugText = JSON.stringify(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() { 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) { 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; } function processExitViewUpdate(item) { 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; } 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] = []; db[event].push({ element: elm, 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(){ var db = {}, exports = {}; exports.addEvent = function(event, callback){ if (!db.hasOwnProperty(event)) db[event] = []; db[event].push(callback); return [event, callback]; }; exports.removeEvent = function(event, callback){ var i; for (i = 0; i < db[event].length; i++) { if (db[event][i] === callback) { db[event].splice(i, 1); return; } } }; exports.performEvent = function(event){ if (!db.hasOwnProperty(event)) return; var staticArguments = Array.prototype.splice.call(arguments, 1, arguments.length); //con.log("performEvent: " + event, staticArguments, arguments); for (var i = 0; i < db[event].length; i++) { try { db[event][i].apply(null, staticArguments); } catch (e) { con.error(e); } } }; return exports; })(); 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; 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"); 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"); 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"); } } }; 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() { var i; for (i = 0; i < unloadEventList.length; i++) { ytcenter.events.removeEvent(unloadEventList[i][0], unloadEventList[i][1]); } 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.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) { try{ if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { return (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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")) + " - " + (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : ytcenter.language.getLocale("SETTINGS_RESIZE_CENTER")) + (item.config.scrollToPlayer ? " - " + ytcenter.language.getLocale("SETTINGS_RESIZE_SCROLLTOPLAYER") : ""); } }catch(e){con.error(e)} } 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(){ 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.saveSettings(); loc.reload(); } } ]), 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); } else { pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_VALIDATE_ERROR_NOT_VALID"), "#ff0000", 3500); } }; reader.readAsText(file.slice(0, VALIDATOR_STRING.length)); }, readFile = function(file){ 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){ settingsPool.value = e.target.result; pushMessage(ytcenter.language.getLocale("SETTINGS_IMEX_IMPORT_MESSAGE"), "", 10000); }; reader.readAsText(file.slice(VALIDATOR_STRING.length)); }, 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"); var settingsPoolChecker = function(){ try { JSON.parse(settingsPool.value); dialog.getActionButton("save").disabled = false; settingsPool.style.background = ""; saveEnabled = true; } catch (e) { dialog.getActionButton("save").disabled = true; settingsPool.style.background = "#FFAAAA"; saveEnabled = false; } }; 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 = ""; }); ytcenter.utils.addEventListener(exportFileButton, "click", function(){ try { var blob = new ytcenter.unsafe.io.Blob([VALIDATOR_STRING + settingsPool.value], { "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(){ 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": "watch-like-dislike-buttons", "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 (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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")) + " - " + (item.config.align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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(); }, 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 (item.getConfig().align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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")) + " - " + (item.getConfig().align ? ytcenter.language.getLocale("SETTINGS_RESIZE_ALIGN") : 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 }; })(); // @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); 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; } 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; } }; ytcenter.utils.isParent = function(parent, child){ var children = parent.getElementsByTagName(child.tagName); for (var i = 0, len = children.length; i < len; i++) { if (children[i] === child) { return true; } } return false; }; ytcenter.utils.once = function(func) { var ran = false, memo; return function() { if (ran) return memo; ran = true; memo = func.apply(this, arguments); func = null; return memo; }; }; ytcenter.utils.isContainerOverflowed = function(a){ // Possible going to use this one // AKA Is the container bigger on the inside than the outside? return { x: a.scrollWidth > a.clientWidth, y: a.scrollHeight > a.clientHeight }; }; ytcenter.utils.isScrollable = function(a){ var b = ytcenter.utils.getOverflow(a); if (!b.x && !b.y) return false; return { x: b.x && a.scrollWidth > a.clientWidth, y: b.y && a.scrollHeight > a.clientHeight }; }; ytcenter.utils.getOverflow = function(a){ var b = ytcenter.utils.getComputedStyles(a), c = { auto: true, scroll: true, visible: false, hidden: false }; return { x: c[b.overflowX.toLowerCase()], y: c[b.overflowY.toLowerCase()] }; }; ytcenter.utils.getComputedStyles = function(a){ if (!a) return {}; if (document && document.defaultView && document.defaultView.getComputedStyle) return document.defaultView.getComputedStyle(a, null); return a.currentStyle; }; ytcenter.utils.getComputedStyle = function(a, b) { return ytcenter.utils.getComputedStyles(a)[b]; }; ytcenter.utils.getBoundingClientRect = function(a) { var b; if (!a) return null; try { b = a.getBoundingClientRect(); b = { left: b.left, top: b.top, right: b.right, bottom: b.bottom }; } catch (c) { return { left: 0, top: 0, right: 0, bottom: 0 } } if (a.ownerDocument.body) { a = a.ownerDocument; b.left -= a.documentElement.clientLeft + a.body.clientLeft; b.top -= a.documentElement.clientTop + a.body.clientTop; } return b; }; ytcenter.utils.getDimension = function(elm){ if (!elm) return { width: 0, height: 0 }; return { width: elm.offsetWidth, height: elm.offsetHeight }; }; ytcenter.utils.isElementPartlyInView = function(elm, offset, winDim){ var box = ytcenter.utils.getBoundingClientRect(elm) || { left: 0, top: 0, right: 0, bottom: 0 }, dim = ytcenter.utils.getDimension(elm), a = elm, b, c, d; offset = offset || { top: 0, left: 0 }; winDim = winDim || {width: window.innerWidth || document.documentElement.clientWidth, height: window.innerHeight || document.documentElement.clientHeight }; return (box.top + offset.top >= 0 - dim.height && box.left + offset.left >= 0 - dim.width && box.bottom + offset.top <= winDim.height + dim.height && box.right + offset.left <= winDim.width + dim.width); }; ytcenter.utils.isElementInView = function(elm){ // TODO Implement scrollable elements support. if (ytcenter.utils.getComputedStyle(elm, "display").toLowerCase() === "none") return false; var box = ytcenter.utils.getBoundingClientRect(elm) || { left: 0, top: 0, right: 0, bottom: 0 }, a = elm, b, c; while (!!(a = a.parentNode) && a !== document.body) { if (ytcenter.utils.getComputedStyle(a, "display").toLowerCase() === "none") return false; b = ytcenter.utils.isContainerOverflowed(a); if (b.x || b.y) { c = ytcenter.utils.getBoundingClientRect(a) || { left: 0, top: 0, right: 0, bottom: 0 }; c.top = c.top - box.top + a.scrollTop; c.left = c.left - box.left + a.scrollLeft; c.bottom = c.bottom - box.bottom + a.scrollTop; c.right = c.right - box.right + a.scrollLeft; if (!(c.top >= 0 && c.left >= 0 && c.bottom <= a.clientHeight && c.right <= a.clientWidth)) return false; // We now know that the element is visible in the parent and therefore we can just check if the parent is visible ~magic. return ytcenter.utils.isElementInView(a); } }; return (box.top >= 0 && box.left >= 0 && box.bottom <= (window.innerHeight || document.documentElement.clientHeight) && box.right <= (window.innerWidth || document.documentElement.clientWidth)); }; ytcenter.utils.getVideoIdFromLink = function(url){ var videoIdRegex = /v=([a-zA-Z0-9-_]+)/, indexRegex = /index=([0-9]+)/, videoIdsRegex = /video_ids=([0-9a-zA-Z-_%]+)/, i = 0, a; if (url.match(videoIdRegex)) { a = videoIdRegex.exec(url); if (a && a[1]) return a[1]; } else if (url.match(videoIdsRegex)) { a = indexRegex.exec(url); if (a && a[1]) { i = parseInt(a[1]); } a = videoIdsRegex.exec(url); if (a && a[1] && a[1].split("%2C").length > 0 && a[1].split("%2C")[i]) { return a[1].split("%2C")[i]; } } return null; }; ytcenter.utils.replaceTextAsString = function(text, rep) { if (!text) return text; var tmp = ""; var startB = false; var func = ""; var tmpName = ""; var tmpFunc = ""; var inFunc = false; for (var i = 0; i < text.length; i++) { if (text.charAt(i) == "{" && !startB && !inFunc) { startB = true; } else if (text.charAt(i) == "}" && startB) { var t = tmpName; for (var key in rep) { if (rep.hasOwnProperty(key)) { if (key === tmpName) { tmpName = ""; t = rep[key]; break; } } } tmp += t; startB = false; } else if (startB) { if (tmpName == "" && text.charAt(i) == "!") { tmp += "{"; startB = false; } else { tmpName += text.charAt(i); } } else { tmp += text.charAt(i); } } return tmp; }; ytcenter.utils.replaceTextToText = function(text, replacer){ var regex, arr = [], tmp = ""; text = text || ""; for (key in replacer) { if (replacer.hasOwnProperty(key)) { arr.push(ytcenter.utils.escapeRegExp(key)); } } regex = new RegExp(arr.join("|") + "|.", "g"); text.replace(regex, function(matched){ if (replacer[matched]) { if (typeof replacer[matched] === "function") { var a = replacer[matched](); if (typeof a === "string") { tmp += a; } else { con.error("[TextReplace] Unknown type of replacer!"); } } else if (typeof replacer[matched] === "string") { tmp += replacer[matched]; } else if (typeof replacer[matched] === "number") { tmp += replacer[matched]; } else { con.error("[TextReplace] Unknown type of replacer!"); } } else { tmp += matched; } }); return tmp; }; ytcenter.utils.guid = function(){ function S4() { return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1); } return S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4(); }; ytcenter.utils.srtTimeFormat = function(totalSeconds){ var sec_num = Math.floor(totalSeconds), hours = Math.floor(sec_num / 3600), minutes = Math.floor((sec_num - (hours * 3600)) / 60), seconds = sec_num - (hours * 3600) - (minutes * 60), milliseconds = Math.round((totalSeconds - sec_num)*100); if (hours < 10) hours = "0" + hours; if (minutes < 10) minutes = "0" + minutes; if (seconds < 10) seconds = "0" + seconds; if (milliseconds < 100) milliseconds = "0" + milliseconds; if (milliseconds < 10) milliseconds = "0" + milliseconds; return hours + ":" + minutes + ":" + seconds + "," + milliseconds; }; ytcenter.utils.parseXML = function(rawxml){ var doc; if (uw.DOMParser) { var parser = new uw.DOMParser(); doc = parser.parseFromString(rawxml, "text/xml"); } else if (uw.ActiveXObject) { doc = new uw.ActiveXObject("Microsoft.XMLDOM"); doc.async = false; doc.loadXML(rawxml); } else { throw new Error("[XMLParser] Cannot parse XML!"); } return doc; }; ytcenter.utils.getURL = function(url){ var a = document.createElement("a"); a.href = url; return a; }; ytcenter.utils.wrapModule = function(module, tagname){ var a = document.createElement(tagname || "span"); a.appendChild(module.element); return a; }; ytcenter.utils.transformToArray = function(domArray){ var a = [], i; for (i = 0; i < domArray.length; i++) { a.push(domArray[i]); } return a; }; ytcenter.utils.decodeHTML = function(a){ return a.replace(/&([^;]+);/g, function(a, c){ switch (c) { case "amp": return "&"; case "lt": return "<"; case "gt": return ">"; case "quot": return '"'; default: if ("#" == c.charAt(0)) { var d = Number("0" + c.substr(1)); if (!isNaN(d)) return String.fromCharCode(d) } return a } }) }; ytcenter.utils.decode = function(a){ var b = { "&": "&", "<": "<", ">": ">", """: '"' }, c = window.document.createElement("div"); return a.replace(/&([^;\s<&]+);?/g, function(a, e){ var g = b[a]; if (g) return g; if ("#" == e.charAt(0)) { var h = Number("0" + e.substr(1)); (0, window.isNaN)(h) || (g = String.fromCharCode(h)) } g || (c.innerHTML = a + " ", g = c.firstChild.nodeValue.slice(0, -1)); return b[a] = g }) }; ytcenter.utils.encodeRawTag = function(text){ var a = document.createElement("a"), b = document.createElement("div"); a.setAttribute("class", text); b.appendChild(a); return b.innerHTML.substring("<a class=\"".length, b.innerHTML.length - "\"></a>".length); }; ytcenter.utils.decodeRawTag = function(text){ var a = document.createElement("div"); a.innerHTML = "<a class=\"" + text + "\"></a>"; return a.firstChild.getAttribute("class"); }; ytcenter.utils.setterGetterClassCompatible = function(){ try { var a_getter = false, a_setter = false, a_instance, a_confirm = "WORKS"; a_instance = defineLockedProperty({}, "test", function(value){a_setter = value === a_confirm}, function(){a_getter = true;return a_confirm;}); if (a_confirm === a_instance.test) { a_instance.test = a_confirm; if (a_getter && a_setter) return true; } } catch (e) { con.error(e); return false; } return false; }; ytcenter.utils.isNode = function(a){ if (typeof Node === "object") { return a instanceof Node; } else if (a && typeof a === "object" && typeof a.nodeType === "number" && typeof a.nodeName === "string") { return true; } return false; }; ytcenter.utils.escapeRegExp = function(str) { return str.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"); }; ytcenter.utils.replaceTextAsString = function(text, rep) { if (!text) return text; var tmp = ""; var startB = false; var func = ""; var tmpName = ""; var tmpFunc = ""; var inFunc = false; for (var i = 0; i < text.length; i++) { if (text.charAt(i) == "{" && !startB && !inFunc) { startB = true; } else if (text.charAt(i) == "}" && startB) { var t = tmpName; for (var key in rep) { if (rep.hasOwnProperty(key)) { if (key === tmpName) { tmpName = ""; t = rep[key]; break; } } } tmp += t; startB = false; } else if (startB) { if (tmpName == "" && text.charAt(i) == "!") { tmp += "{"; startB = false; } else { tmpName += text.charAt(i); } } else { tmp += text.charAt(i); } } return tmp; }; /** This will replace strings in a text with other strings or HTML elements. * replacer : { * "__REPLACEDSTRING__": document.createElement("div"), * "{REPLACESTRING}": "ANOTHER STRING" * } */ ytcenter.utils.replaceText = function(text, replacer){ var frag = document.createDocumentFragment(), regex, arr = [], tmp = ""; for (key in replacer) { if (replacer.hasOwnProperty(key)) { arr.push(ytcenter.utils.escapeRegExp(key)); } } regex = new RegExp(arr.join("|") + "|.", "g"); text.replace(regex, function(matched){ if (replacer[matched]) { if (tmp !== "") { frag.appendChild(document.createTextNode(tmp)); tmp = ""; } if (typeof replacer[matched] === "function") { var a = replacer[matched](); if (typeof a === "string") { frag.appendChild(document.createTextNode(a)); } else if (ytcenter.utils.isNode(a)) { frag.appendChild(a); } else { con.error("[TextReplace] Unknown type of replacer!"); } } else if (typeof replacer[matched] === "string") { frag.appendChild(document.createTextNode(replacer[matched])); } else if (ytcenter.utils.isNode(replacer[matched])) { frag.appendChild(replacer[matched]); } else { con.error("[TextReplace] Unknown type of replacer!"); } } else { tmp += matched; } }); if (tmp !== "") { frag.appendChild(document.createTextNode(tmp)); tmp = ""; } return frag; }; ytcenter.utils._escape_html_entities = [ [" ", "¡", "¢", "£", "¤", "¥", "¦", "§", "¨", "©", "ª", "«", "¬", "­", "®", "¯", "°", "±", "²", "³", "´", "µ", "¶", "·", "¸", "¹", "º", "»", "¼", "½", "¾", "¿", "À", "Á", "Â", "Ã", "Ä", "Å", "Æ", "Ç", "È", "É", "Ê", "Ë", "Ì", "Í", "Î", "Ï", "Ð", "Ñ", "Ò", "Ó", "Ô", "Õ", "Ö", "×", "Ø", "Ù", "Ú", "Û", "Ü", "Ý", "Þ", "ß", "à", "á", "â", "ã", "ä", "å", "æ", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", "ð", "ñ", "ò", "ó", "ô", "õ", "ö", "÷", "ø", "ù", "ú", "û", "ü", "ý", "þ", "ÿ", """, "&", "<", ">", "Œ", "œ", "Š", "š", "Ÿ", "ˆ", "˜", " ", " ", " ", "‌", "‍", "‎", "‏", "–", "—", "‘", "’", "‚", "“", "”", "„", "†", "‡", "‰", "‹", "›", "€", "ƒ", "Α", "Β", "Γ", "Δ", "Ε", "Ζ", "Η", "Θ", "Ι", "Κ", "Λ", "Μ", "Ν", "Ξ", "Ο", "Π", "Ρ", "Σ", "Τ", "Υ", "Φ", "Χ", "Ψ", "Ω", "α", "β", "γ", "δ", "ε", "ζ", "η", "θ", "ι", "κ", "λ", "μ", "ν", "ξ", "ο", "π", "ρ", "ς", "σ", "τ", "υ", "φ", "χ", "ψ", "ω", "ϑ", "ϒ", "ϖ", "•", "…", "′", "″", "‾", "⁄", "℘", "ℑ", "ℜ", "™", "ℵ", "←", "↑", "→", "↓", "↔", "↵", "⇐", "⇑", "⇒", "⇓", "⇔", "∀", "∂", "∃", "∅", "∇", "∈", "∉", "∋", "∏", "∑", "−", "∗", "√", "∝", "∞", "∠", "∧", "∨", "∩", "∪", "∫", "∴", "∼", "≅", "≈", "≠", "≡", "≤", "≥", "⊂", "⊃", "⊄", "⊆", "⊇", "⊕", "⊗", "⊥", "⋅", "⌈", "⌉", "⌊", "⌋", "⟨", "⟩", "◊", "♠", "♣", "♥", "♦"], [" ", "¡", "¢", "£", "¤", "¥", "¦", "§", "¨", "©", "ª", "«", "¬", "­", "®", "¯", "°", "±", "²", "³", "´", "µ", "¶", "·", "¸", "¹", "º", "»", "¼", "½", "¾", "¿", "À", "Á", "Â", "Ã", "Ä", "Å", "Æ", "Ç", "È", "É", "Ê", "Ë", "Ì", "Í", "Î", "Ï", "Ð", "Ñ", "Ò", "Ó", "Ô", "Õ", "Ö", "×", "Ø", "Ù", "Ú", "Û", "Ü", "Ý", "Þ", "ß", "à", "á", "â", "ã", "ä", "å", "æ", "ç", "è", "é", "ê", "ë", "ì", "í", "î", "ï", "ð", "ñ", "ò", "ó", "ô", "õ", "ö", "÷", "ø", "ù", "ú", "û", "ü", "ý", "þ", "ÿ", """, "&", "<", ">", "Œ", "œ", "Š", "š", "Ÿ", "ˆ", "˜", " ", " ", " ", "‌", "‍", "‎", "‏", "–", "—", "‘", "’", "‚", "“", "”", "„", "†", "‡", "‰", "‹", "›", "€", "ƒ", "Α", "Β", "Γ", "Δ", "Ε", "Ζ", "Η", "Θ", "Ι", "Κ", "Λ", "Μ", "Ν", "Ξ", "Ο", "Π", "Ρ", "Σ", "Τ", "Υ", "Φ", "Χ", "Ψ", "Ω", "α", "β", "γ", "δ", "ε", "ζ", "η", "θ", "ι", "κ", "λ", "μ", "ν", "ξ", "ο", "π", "ρ", "ς", "σ", "τ", "υ", "φ", "χ", "ψ", "ω", "ϑ", "ϒ", "ϖ", "•", "…", "′", "″", "‾", "⁄", "℘", "ℑ", "ℜ", "™", "ℵ", "←", "↑", "→", "↓", "↔", "↵", "⇐", "⇑", "⇒", "⇓", "⇔", "∀", "∂", "∃", "∅", "∇", "∈", "∉", "∋", "∏", "∑", "−", "∗", "√", "∝", "∞", "∠", "∧", "∨", "∩", "∪", "∫", "∴", "∼", "≅", "≈", "≠", "≡", "≤", "≥", "⊂", "⊃", "⊄", "⊆", "⊇", "⊕", "⊗", "⊥", "⋅", "⌈", "⌉", "⌊", "⌋", "〈", "〉", "◊", "♠", "♣", "♥", "♦"] ]; ytcenter.utils.escapeXML = function(str){ return ytcenter.utils.replaceArray(str, ["<", ">", "&", "\"", "'"], ["<", ">", "&", """, "'"]); }; ytcenter.utils.unescapeXML = function(str){ return ytcenter.utils.replaceArray(str, ["<", ">", "&", """, "'"], ["<", ">", "&", "\"", "'"]); }; ytcenter.utils.escapeHTML = function(str){ if (str === "") return ""; var i, a = ""; for (i = 0; i < str.length; i++) { switch (str[i]) { case "<": a += "<"; break; case ">": a += ">"; break; case "&": a += "&"; break; case "\"": a += """; break; case "'": a += "'"; break; default: if (str[i] < " " || str[i] > "~") a += "&#" + (str.charCodeAt(i)) + ";"; else a += str[i]; break; } if (str[i] === "<") { a += "<"; } } return a; }; ytcenter.utils.unescapeHTML = function(str){ if (typeof str !== "string" || str === "") return ""; str = ytcenter.utils.replaceArray(str, ytcenter.utils._escape_html_entities[0], ytcenter.utils._escape_html_entities[1]); var i, a = str.match(/&#[0-9]{1,5};/g), b, c; if (!a) return str; for (i = 0; i < a.length; i++) { b = a[i]; c = b.substring(2, b.length - 1); if (c > -32769 && c < 65536) { str = str.replace(b, String.fromCharCode(c)); } else { str = str.replace(b, ""); } } return str; }; ytcenter.utils.replaceArray = function(str, find, replace){ var i; if (find.length !== replace.length) throw "The find & replace array doesn't have the same length!"; for (i = 0; i < find.length; i++) { str = str.replace(new RegExp(find[i], "g"), replace[i]); } return str; }; ytcenter.utils.number1000Formating = function(num){ var i, j = 0, r = [], tmp = ""; num = num + ""; for (i = num.length - 1; i >= 0; i--) { tmp = num[i] + tmp; if (tmp.length === 3) { r.unshift(tmp); tmp = ""; } } if (tmp !== "") r.unshift(tmp); return r.join(","); }; ytcenter.utils.xhr = function(details){ ytcenter.unsafeCall("xhr", [details], null); }; ytcenter.utils.getScrollOffset = function(){ var top = Math.max(document.body.scrollTop, document.documentElement.scrollTop); var left = Math.max(document.body.scrollLeft, document.documentElement.scrollLeft); return {top:top,left:left}; }; ytcenter.utils.addEventListener = (function(){ var listeners = []; ytcenter.unload(function(){ var i; for (i = 0; i < listeners.length; i++) { if (listeners[i].elm.removeEventListener) { listeners[i].elm.removeEventListener(listeners[i].event, listeners[i].callback, listeners[i].useCapture || false); } } listeners = []; }); ytcenter.utils.removeEventListener = function(elm, event, callback, useCapture){ var i; if (elm.removeEventListener) { elm.removeEventListener(event, callback, useCapture || false); } for (i = 0; i < listeners.length; i++) { if (listeners[i].elm === elm && listeners[i].event === event && listeners[i].callback === callback && listeners[i].useCapture === useCapture) { listeners.splice(i, 1); break; } } }; return function(elm, event, callback, useCapture){ if (!elm) return; listeners.push({elm: elm, event: event, callback: callback, useCapture: useCapture}); if (elm.addEventListener) { elm.addEventListener(event, callback, useCapture || false); } else if (elm.attachEvent) { elm.attachEvent("on" + event, callback); } }; })(); ytcenter.utils.getRGB = function(h, s, v){ h = h/360 * 6; s = s/100; v = v/100; var i = Math.floor(h), f = h - i, p = v * (1 - s), q = v * (1 - f * s), t = v * (1 - (1 - f) * s), mod = i % 6, r = [v, q, p, p, t, v][mod], g = [t, v, v, q, p, p][mod], b = [p, p, t, v, v, q][mod]; return {red: r * 255, green: g * 255, blue: b * 255}; }; ytcenter.utils.getHSV = function(r, g, b) { var max = Math.max(r, g, b), min = Math.min(r, g, b); var h, s, v = max; var d = max - min; s = max === 0 ? 0 : d / max; if (max == min) { h = 0; } else { switch (max) { case r: h = (g - b) / d + (g < b ? 6 : 0); break; case g: h = (b - r) / d + 2; break; case b: h = (r - g) / d + 4; break; } h /= 6; } return {hue: h*360, saturation: s*100, value: v/255*100}; }; ytcenter.utils.hsvToHex = function(hue, sat, val){ var rgb = ytcenter.utils.getRGB(hue, sat, val); return ytcenter.utils.colorToHex(rgb.red, rgb.green, rgb.blue); }; ytcenter.utils.colorToHex = function(red, green, blue){ red = Math.round(red); green = Math.round(green); blue = Math.round(blue); if (red > 255) red = 255; if (red < 0) red = 0; if (green > 255) green = 255; if (green < 0) green = 0; if (blue > 255) blue = 255; if (blue < 0) blue = 0; var r = red.toString(16); if (r.length === 1) r = "0" + r; var g = green.toString(16); if (g.length === 1) g = "0" + g; var b = blue.toString(16); if (b.length === 1) b = "0" + b; r = r.toUpperCase(); g = g.toUpperCase(); b = b.toUpperCase(); return "#" + r + g + b; }; ytcenter.utils.hexToColor = function(hex){ if (hex.indexOf("#") === 0) hex = hex.substring(1); var r,g,b; if (hex.length === 6) { r = parseInt(hex.substring(0, 2), 16); g = parseInt(hex.substring(2, 4), 16); b = parseInt(hex.substring(4, 6), 16); } else if (hex.length === 3) { r = parseInt(hex.substring(0, 1) + hex.substring(0, 1), 16); g = parseInt(hex.substring(1, 2) + hex.substring(1, 2), 16); b = parseInt(hex.substring(2, 3) + hex.substring(2, 3), 16); } else { r = 0; g = 0; b = 0; } return {red: r, green: g, blue: b}; }; ytcenter.utils.setKeyword = function(keywords, key, value){ var a = keywords.split(","); for (var i = 0; i < a.length; i++) { if (a[i].split("=")[0] === "key") { if (typeof value === "string") { a[i] = key + "=" + value; } else { a[i] = key; } return a.join(","); } } if (typeof value === "string") { a.push(key + "=" + value); } else { a.push(key); } return a.join(","); }; ytcenter.utils.updateSignatureDecipher = function(){ //ytcenter.utils.updateSignatureDecipher = function(){}; // I'm just cheating a little bit ... if (ytcenter && ytcenter.player && ytcenter.player.config && ytcenter.player.config.assets && ytcenter.player.config.assets.js) { var js = (loc.href.indexOf("https") === 0 ? "https:" : "http:") + ytcenter.player.config.assets.js, regex = /function [a-zA-Z$0-9]+\(a\){a=a\.split\(""\);(.*?)return a\.join\(""\)}/g, regex2 = /function [a-zA-Z$0-9]+\(a\){a=a\.split\(""\);(((a=([a-zA-Z$0-9]+)\(a,([0-9]+)\);)|(a=a\.slice\([0-9]+\);)|(a=a\.reverse\(\);)|(var b=a\[0\];a\[0\]=a\[[0-9]+%a\.length\];a\[[0-9]+\]=b;)))*return a\.join\(""\)}/g; con.log("[updateSignatureDecipher] Contacting " + js); ytcenter.utils.xhr({ method: "GET", url: js, onload: function(response) { var a,i,b,v; if (response.responseText.match(regex2)) { con.log("[updateSignatureDecipher] Using regex 1"); a = regex2.exec(response.responseText)[0].split("{")[1].split("}")[0].split(";"); ytcenter.settings['signatureDecipher'] = []; // Clearing signatureDecipher for (i = 1; i < a.length-1; i++) { b = a[i]; if (b.indexOf("a.slice") !== -1) { // Slice v = b.split("(")[1].split(")")[0]; ytcenter.settings['signatureDecipher'].push({func: "slice", value: parseInt(v)}); } else if (b.indexOf("a.reverse") !== -1) { // Reverse ytcenter.settings['signatureDecipher'].push({func: "reverse", value: null}); } else if ((a[i] + ";" + a[i+1] + ";" + a[i+2]).indexOf("var b=a[0];a[0]=a[") !== -1){ // swapHeadAndPosition v = (a[i] + ";" + a[i+1] + ";" + a[i+2]).split("var b=a[0];a[0]=a[")[1].split("%")[0]; ytcenter.settings['signatureDecipher'].push({func: "swapHeadAndPosition", value: parseInt(v)}); i = i+2; } else { // swapHeadAndPosition (maybe it's deprecated by YouTube) v = b.split("(a,")[1].split(")")[0]; ytcenter.settings['signatureDecipher'].push({func: "swapHeadAndPosition", value: parseInt(v)}); } } } else if (response.responseText.match(regex)) { con.log("[updateSignatureDecipher] Using regex 2"); a = regex.exec(response.responseText)[1]; if (a.match(/a=([a-zA-Z0-9]+)\.([a-zA-Z0-9]+)\(a,([0-9]+)\)/g)) { var commonObject = null; var arr = a.split(";"); var methods = []; var methodValues = []; for (var i = 0, len = arr.length - 1; i < len; i++) { var tokens = /a=([a-zA-Z0-9]+)\.([a-zA-Z0-9]+)\(a,([0-9]+)\)/g.exec(arr[i]); if (commonObject !== tokens[1] && commonObject !== null) { throw "Unknown cipher method!"; } else { commonObject = tokens[1]; } methods.push(tokens[2]); methodValues.push(tokens[3]); } var prefix = "var " + ytcenter.utils.escapeRegExp(commonObject) + "=\\{("; var uniqueMethods = []; var regexMeth = []; for (var i = 0, len = methods.length; i < len; i++) { if (!ytcenter.utils.inArray(uniqueMethods, methods[i])) { uniqueMethods.push(methods[i]); regexMeth.push(ytcenter.utils.escapeRegExp(methods[i])); } } for (var i = 0, len = uniqueMethods.length; i < len; i++) { if (i > 0) prefix += "|"; prefix += "(([a-zA-Z0-9]+):function\\(([a-zA-Z0-9,]+)\\)\\{(.*?)\\}[,]?)"; } prefix += ")\\}"; var regexMethod = new RegExp(prefix, "g").exec(response.responseText); var definedFunctions = new RegExp("([a-zA-Z0-9]+):function\\(([a-zA-Z0-9,]+)\\)\\{(.*?)\\}", "g"); ytcenter.settings['signatureDecipher'] = []; var definedFunction; while (definedFunction = definedFunctions.exec(regexMethod[0])) { ytcenter.settings['signatureDecipher'].push({ func: "function", name: definedFunction[1], value: definedFunction[3] }); } for (var i = 0, len = methods.length; i < len; i++) { ytcenter.settings['signatureDecipher'].push({ func: "call", name: methods[i], value: methodValues[i] }); } } else if (a.match(/([a-zA-Z0-9]+)\.([a-zA-Z0-9]+)\(a,([0-9]+)\)/g)) { var commonObject = null; var arr = a.split(";"); var methods = []; var methodValues = []; for (var i = 0, len = arr.length - 1; i < len; i++) { var tokens = /([a-zA-Z0-9]+)\.([a-zA-Z0-9]+)\(a,([0-9]+)\)/g.exec(arr[i]); if (commonObject !== tokens[1] && commonObject !== null) { throw "Unknown cipher method!"; } else { commonObject = tokens[1]; } methods.push(tokens[2]); methodValues.push(tokens[3]); } var prefix = "var " + ytcenter.utils.escapeRegExp(commonObject) + "=\\{("; var uniqueMethods = []; var regexMeth = []; for (var i = 0, len = methods.length; i < len; i++) { if (!ytcenter.utils.inArray(uniqueMethods, methods[i])) { uniqueMethods.push(methods[i]); regexMeth.push(ytcenter.utils.escapeRegExp(methods[i])); } } for (var i = 0, len = uniqueMethods.length; i < len; i++) { if (i > 0) prefix += "|"; prefix += "(([a-zA-Z0-9]+):function\\(([a-zA-Z0-9,]+)\\)\\{(.*?)\\}[,]?)"; } prefix += ")\\}"; var regexMethod = new RegExp(prefix, "g").exec(response.responseText); var definedFunctions = new RegExp("([a-zA-Z0-9]+):function\\(([a-zA-Z0-9,]+)\\)\\{(.*?)\\}", "g"); ytcenter.settings['signatureDecipher'] = []; var definedFunction; while (definedFunction = definedFunctions.exec(regexMethod[0])) { ytcenter.settings['signatureDecipher'].push({ func: "function", name: definedFunction[1], value: definedFunction[3] + ";return a;" }); } for (var i = 0, len = methods.length; i < len; i++) { ytcenter.settings['signatureDecipher'].push({ func: "call", name: methods[i], value: methodValues[i] }); } } else { ytcenter.settings['signatureDecipher'] = []; // Clearing signatureDecoder ytcenter.settings['signatureDecipher'].push({ func: "code", value: a }); } } else { con.error("[updateSignatureDecipher] Couldn't retrieve the signatureDecipher!"); } ytcenter.events.performEvent("ui-refresh"); ytcenter.saveSettings(); }, onerror: function() { con.error("[SignatureDecipher] Couldn't download data!"); } }); } }; ytcenter.utils.signatureDecipher = function(signatureCipher, decipherRecipe){ function swapHeadAndPosition(array, position) { var head = array[0]; var other = array[position % array.length]; array[0] = other; array[position] = head; return array; } if (!signatureCipher) return ""; var cipherArray = signatureCipher.split(""), i; decipherRecipe = decipherRecipe || ytcenter.settings['signatureDecipher']; var funcMap = {}; for (i = 0; i < decipherRecipe.length; i++) { if (decipherRecipe[i].func === "function") { funcMap[decipherRecipe[i].name] = new Function("a", "b", decipherRecipe[i].value); } else if (decipherRecipe[i].func === "call") { cipherArray = funcMap[decipherRecipe[i].name](cipherArray, decipherRecipe[i].value); } else if (decipherRecipe[i].func === "code") { cipherArray = new Function("a", decipherRecipe[i].value + "return a.join(\"\")")(cipherArray); } else if (decipherRecipe[i].func === "swapHeadAndPosition") { cipherArray = swapHeadAndPosition(cipherArray, decipherRecipe[i].value); } else if (decipherRecipe[i].func === "slice") { cipherArray = cipherArray.slice(decipherRecipe[i].value); } else if (decipherRecipe[i].func === "reverse") { cipherArray = cipherArray.reverse(); } } if (!ytcenter.utils.isArray(cipherArray)) return signatureCipher; return cipherArray.join(""); }; ytcenter.utils.crypt_h = void 0; ytcenter.utils.crypt_l = !0; ytcenter.utils.crypt_p = !1; ytcenter.utils.crypt_Ej = ytcenter.utils.crypt_h; ytcenter.utils.crypt = function(){ try { var a; try { if (ytcenter.utils.crypt_Ej == ytcenter.utils.crypt_h && (ytcenter.utils.crypt_Ej = ytcenter.utils.crypt_p, window.crypto && window.crypto.wx)) { try { a = new Uint8Array(1), window.crypto.wx(a), ytcenter.utils.crypt_Ej = ytcenter.utils.crypt_l } catch (b) { } } } catch (e) { con.error(e); } if (ytcenter.utils.crypt_Ej) { a = Array(16); var c = new Uint8Array(16); window.crypto.getRandomValues(c); for (var d = 0; d < a.length; d++) a[d] = c[d] } else { a = Array(16); for (c = 0; 16 > c; c++) { for (var d = ytcenter.utils.now(), f = 0; f < d % 23; f++) a[c] = Math.random(); a[c] = Math.floor(64 * Math.random()) } } c = []; for (d = 0; d < a.length; d++) c.push("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_"[a[d] & 63]); return c.join(""); } catch (e) { con.error(e); } }; ytcenter.utils.calculateDimensions = function(width, height, player_ratio){ player_ratio = player_ratio || 16/9; var calcWidth, calcHeight; var widthType, heightType; if (width.indexOf("%") !== -1 && width.match(/%$/)) { widthType = "%"; } else { widthType = "px"; } if (height.indexOf("%") !== -1 && height.match(/%$/)) { heightType = "%"; } else { heightType = "px"; } if (widthType === "px") { calcWidth = parseInt(width); } else { calcWidth = width; } if (heightType === "px") { calcHeight = parseInt(height); } else { calcHeight = height; } if (widthType === "px" && heightType === "px") { if (!isNaN(parseInt(width)) && isNaN(parseInt(height))) { calcHeight = Math.round(calcWidth/player_ratio); } else if (isNaN(parseInt(width)) && !isNaN(parseInt(height))) { calcWidth = Math.round(calcHeight*player_ratio); } } return [calcWidth, calcHeight]; }; ytcenter.utils.bindArgument = function(func) { var sargs = Array.prototype.splice.call(arguments, 1, arguments.length); return function() { var args = Array.prototype.slice.call(sargs); Array.prototype.push.apply(args, arguments); return func.apply(null, args); }; }; ytcenter.utils.bind = function(scope, func) { var args = Array.prototype.slice.call(arguments, 2); return function(){ return func.apply(scope, args.concat(Array.prototype.slice.call(arguments))) }; }; ytcenter.utils.oldBind = function(func){ return func.call.apply(func.bind, arguments); }; ytcenter.utils.query = function(key){ if (loc.search.indexOf("?") === 0) { var a = loc.search.substring(1).split("&"); for (var i = 0; i < a.length; i++) { if (decodeURIComponent(a[i].split("=")[0]) === key) { return decodeURIComponent(a[i].split("=")[1]); } } } }; ytcenter.utils.now = Date.now || function () { return +new Date; }; ytcenter.utils.setCookie = function(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(ytcenter.utils.now() + 1E3 * expires)).toUTCString(); document.cookie = encodeURIComponent(name) + "=" + encodeURIComponent(value) + domain + path + expires; }; ytcenter.utils.getCookie = function(key){ return ytcenter.utils.getCookies()[key]; }; ytcenter.utils.getCookies = function(){ 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; }; ytcenter.utils.assignId = (function(){ var ___count = -1; return function(prefix) { ___count++; var timestamp = (new Date()).getTime(); return (prefix ? prefix : "") + ___count + (timestamp); }; })(); ytcenter.utils.inArrayIndex = function(a, v){ for (var i = 0; i < a.length; i++) { if (a[i] === v) return i; } return -1; }; ytcenter.utils.inArray = function(array, value){ for (var i = 0, len = array.length; i < len; i++) { if (array[i] === value) { return true; } } return false; }; ytcenter.utils.decodeURIArguments = function(uri){ var a = {}; ytcenter.utils.each(uri.split("&"), function(i, item){ var key = decodeURIComponent(item.split("=")[0]); var value = decodeURIComponent(item.split("=")[1]); a[key] = value; }); return a; }; ytcenter.utils.call = function(func, args){ var a = ""; ytcenter.utils.each(args, function(i){ if (i > 0) a += ", "; a += "b[" + i + "]"; }); return new Function("a", "return a(" + a + ")")(func); }; ytcenter.utils.randomString = function(str, len) { var buff = ""; for (var i = 0; i < len; i++) { buff += str[Math.floor(Math.random()*len)]; } return buff; }; ytcenter.utils.insertAfter = function(elm, after){ if (typeof after.parentNode === "undefined") return; if (typeof elm.parentNode !== "undefined") elm.parentNode.removeChild(elm); if (after.parentNode.lastChild === after) { after.parentNode.appendChild(elm); } else { after.parentNode.insertBefore(elm, after.nextSibling); } }; ytcenter.utils.hasChild = function(parent, elm){ var c = parent.children; for (var i = 0; i < c.length; i++) { if (c[i] === elm) return true; if (ytcenter.utils.hasChild(c[i], elm)) return true; } return false; }; ytcenter.utils.toParent = function(elm, className){ while (elm !== document.body && typeof elm !== "undefined") { if (ytcenter.utils.hasClass(elm, className)) return elm; elm = elm.parentNode; } }; ytcenter.utils.isArray = function(arr){ return Object.prototype.toString.call(arr) === "[object Array]"; }; ytcenter.utils.each = function(obj, callback){ if (ytcenter.utils.isArray(obj)) { for (var i = 0; i < obj.length; i++) { if (callback(i, obj[i]) === true) break; } } else { for (var key in obj) { if (obj.hasOwnProperty(key)) { if (callback(key, obj[key]) === true) break; } } } }; ytcenter.utils.mergeArrays = function(){ if (arguments.length <= 0) return []; if (arguments.length === 1) return arguments[0]; var arr = [], i, j; for (i = 0; i < arguments.length; i++) { if (typeof arguments[i] === "undefined") continue; for (j = 0; j < arguments[i].length; j++) { arr.push(arguments[i][j]); } } return arr; } ytcenter.utils.mergeObjects = function(){ if (arguments.length <= 0) return {}; if (arguments.length === 1) return arguments[0]; var _o = arguments[0]; for (var i = 1; i < arguments.length; i++) { if (typeof arguments[i] === "undefined") continue; ytcenter.utils.each(arguments[i], function(key, value){ var type = Object.prototype.toString.call(value); if (_o[key] && (type === "[object Array]" || type === "[object Object]")) { _o[key] = ytcenter.utils.mergeObjects(_o[key], value); } else { _o[key] = value; } }); } return _o; }; ytcenter.utils.cleanClasses = function(elm){ if (typeof elm === "undefined" || typeof elm.className === "undefined") return; var classNames = elm.className.split(" "), i, _new = []; for (i = 0; i < classNames.length; i++) { if (classNames[i] !== "" && !ytcenter.utils.inArray(_new, classNames[i])) { _new.push(classNames[i]); } } elm.className = _new.join(" "); }; ytcenter.utils.hasClass = function(elm, className){ if (typeof elm === "undefined" || typeof elm.className === "undefined") return; var classNames = elm.className.split(" "), i; for (i = 0; i < classNames.length; i++) { if (classNames[i] === className) return true; } return false; }; ytcenter.utils.toggleClass = function(elm, className){ if (typeof elm === "undefined" || typeof elm.className === "undefined") return; if (ytcenter.utils.hasClass(elm, className)) { ytcenter.utils.removeClass(elm, className); } else { ytcenter.utils.addClass(elm, className); } }; ytcenter.utils.addClass = function(elm, className){ if (typeof elm === "undefined" || typeof elm.className === "undefined") return; var classNames = elm.className.split(" "), addClassNames = className.split(" "), _new = [], i, j, found; for (i = 0; i < addClassNames.length; i++) { found = false; for (j = 0; j < classNames.length; j++) { if (addClassNames[i] === classNames[j]) { found = true; break; } } if (!found) { _new.push(addClassNames[i]); } } elm.className += " " + _new.join(" "); ytcenter.utils.cleanClasses(elm); }; ytcenter.utils.removeClass = function(elm, className){ if (typeof elm === "undefined" || typeof elm.className === "undefined") return; var classNames = elm.className.split(" "), remClassNames = className.split(" "), _new = [], i, j, found; for (var i = 0; i < classNames.length; i++) { if (classNames[i] === "") continue; found = false; for (j = 0; j < remClassNames.length; j++) { if (classNames[i] === remClassNames[j]) { found = true; break; } } if (!found) { _new.push(classNames[i]); } } elm.className = _new.join(" "); }; ytcenter.utils.getOffset = function(elm, toElement){ var _x = 0; var _y = 0; while(elm && elm !== toElement && !isNaN(elm.offsetLeft) && !isNaN(elm.offsetTop)) { _x += elm.offsetLeft - elm.scrollLeft; _y += elm.offsetTop - elm.scrollTop; elm = elm.offsetParent; } return { top: _y, left: _x }; }; ytcenter.utils.getOffScreenX = function(elm, border){ border = border || 0; if (ytcenter.utils.getOffset(elm).left - border < 0) { return ytcenter.utils.getOffset(elm).left + border; } else if (ytcenter.utils.getOffset(elm).left + elm.offsetWidth + border > window.innerWidth) { return ytcenter.utils.getOffset(elm).left + elm.offsetWidth + border - window.innerWidth; } else { return 0; } }; ytcenter.utils.getOffScreenY = function(elm, border){ border = border || 0; if (ytcenter.utils.getOffset(elm).top + border < 0) { return ytcenter.utils.getOffset(elm).top - border; } else if (ytcenter.utils.getOffset(elm).top + elm.offsetWidth > window.innerWidth - border) { return ytcenter.utils.getOffset(elm).top + elm.offsetWidth + border - window.innerWidth; } else { return 0; } }; ytcenter.utils.addCSS = function(id, styles, addElement) { function add() { if (oStyle.parentNode) { con.error("[addCSS] Element already added to document."); } else { if (document && document.body) { document.body.appendChild(oStyle); } else if (document && document.head) { document.head.appendChild(oStyle); } else if (document && document.documentElement) { document.documentElement.appendChild(oStyle); } else if (document) { document.appendChild(oStyle); } else { con.error("[addCSS] Couldn't add style to document!"); } } } function remove() { if (isAdded()) { oStyle.parentNode.removeChild(oStyle); } } function isAdded() { return oStyle && oStyle.parentNode; } if (typeof addElement !== "boolean") { addElement = true; } var oStyle = document.createElement("style"); oStyle.setAttribute("id", "ytcenter-styles-" + id); oStyle.setAttribute("type", "text\/css"); oStyle.appendChild(document.createTextNode(styles + "\n//# sourceURL=" + encodeURIComponent("ytcenter/" + id + ".css"))); if (addElement) { add(); } return { add: add, remove: remove, isAdded: isAdded }; }; ytcenter.utils.createElement = function(tagname, options){ options = options || {}; var elm = document.createElement(tagname); ytcenter.utils.each(options, function(key, value){ if (key === "style" && typeof value === "object") { ytcenter.utils.each(value, function(_key, _value){ elm.style[_key] = _value; }); } else if (key === "listeners" && typeof value === "object") { ytcenter.utils.each(value, function(_key, _value){ if (ytcenter.utils.isArray(_value)) { ytcenter.utils.each(_value, function(i, __value){ ytcenter.utils.addEventListener(elm, _key, __value, false); }); } else { ytcenter.utils.addEventListener(elm, _key, _value, false); } }); } else { elm.setAttribute(key, value); } }); return elm; }; ytcenter.utils.objectKeys = function(obj){ if (typeof obj !== 'object' && (typeof obj !== 'function' || obj === null)) { con.error("ytcenter.utils.objectKeys called on non-object"); } var result = [], key, i; for (key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { result.push(key); } } if (!({toString: null}).propertyIsEnumerable('toString')) { var dontEnums = [ 'toString', 'toLocaleString', 'valueOf', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 'constructor' ], dontEnumsLength = dontEnums.length; for (i = 0; i < dontEnumsLength; i++) { if (Object.prototype.hasOwnProperty.call(obj, dontEnums[i])) { result.push(dontEnums[i]); } } } return result; }; ytcenter.utils.extend = function(what, wit) { var extObj, witKeys = Object.keys(wit); extObj = ytcenter.utils.objectKeys(what).length ? ytcenter.utils.clone(what) : {}; witKeys.forEach(function(key) { Object.defineProperty(extObj, key, Object.getOwnPropertyDescriptor(wit, key)); }); return extObj; } ytcenter.utils.jsonClone = function(obj){ return JSON.parse(JSON.stringify(obj)); }; ytcenter.utils.clone = function(obj){ return ytcenter.utils.extend({}, obj); }; ytcenter.getMutationObserver = function(){ var a; try { a = MutationObserver || uw.MutationObserver || WebKitMutationObserver || uw.WebKitMutationObserver || MozMutationObserver || uw.MozMutationObserver; } catch (e) { try { a = uw.MutationObserver || WebKitMutationObserver || uw.WebKitMutationObserver || MozMutationObserver || uw.MozMutationObserver; } catch (e) { try { a = WebKitMutationObserver || uw.WebKitMutationObserver || MozMutationObserver || uw.MozMutationObserver; } catch (e) { try { a = uw.WebKitMutationObserver || MozMutationObserver || uw.MozMutationObserver; } catch (e) { try { a = MozMutationObserver || uw.MozMutationObserver; } catch (e) { a = uw.MozMutationObserver; } } } } } return a; }; (function(global, propertyName){ function getTargetedGroup(x, y, groups) { var distance = null; var heightGroup = null; for (var i = 0, len = groups.length; i < len; i++) { // Group element var group = groups[i]; // Getting the absolute position of the group element var absolutePosition = utils.getAbsolutePosition(group); /* * The points on the rectangle, which represents the group element. * px is 1 and 2, * py is 1 and 3, * pWidth is 2 and 4, * pHeight is 3 and 4 * 1------------2 * | | * | | * 3------------4 */ var px = absolutePosition.x; var py = absolutePosition.y; var pWidth = absolutePosition.x + group.offsetWidth; var pHeight = absolutePosition.y + group.offsetHeight; // Detecting if the (x, y) point is inside or touches the group element (rectangle) if (x >= px && x <= pWidth && y >= py && y <= pHeight) { return group; } else if (y >= py && y <= pHeight) { var tmpDist = null; if (x < px) { // Left side tmpDist = px - x; } else if (x > pWidth) { // Right side tmpDist = x - pWidth; } else { continue; // This should never happen. } if (distance === null || tmpDist < distance) { heightGroup = group; distance = tmpDist; } } } return heightGroup; } function getRelativeGroupChild(x, y, group) { // The cursor is inside a group element. if (group !== null) { var groupChildren = group.children; // Iterate through every child of group for (var i = 0, len = groupChildren.length; i < len; i++) { var child = groupChildren[i]; // Making sure that an element is not placed beside itself. if (child !== refMoveableElement && child !== refTargetedElement) { // Get the child's absolute position on the page var absolutePosition = utils.getAbsolutePosition(child); // The for loop iterates through the children chronological, which means that // it only needs to look if the x-value of the cursor is before half of the // child element. if (x <= child.offsetWidth/2 + absolutePosition.x && y <= child.offsetHeight + absolutePosition.y) { return child; } } } } // No child was found, return null return null; } function mousemoveListener(e) { if (!mousedown || !moduleEnabled) return; e = e || window.event; // If user is using touch, make sure that it detects the touch instead of mouse. if (e && e.type.indexOf("touch") !== -1 && e.changedTouches && e.changedTouches.length > 0 && e.changedTouches[0]) { e = e.changedTouches[0]; } // The (x, y) coordinate of the mouse cursor on the page var x = e.pageX; var y = e.pageY; // Update the moveable element position refMoveableElement.style.top = (y - (relativeMousePosition.y || 0)) + "px"; refMoveableElement.style.left = (x - (relativeMousePosition.x || 0)) + "px"; // Get the targeted group with the (x, y) coordinate of the cursor var group = getTargetedGroup(x, y, groupElements); if (group) { // Get the relative group child element var child = getRelativeGroupChild(x, y, group); // Make sure that targeted element does have a parent to remove // the element from if (refTargetedElement.parentNode) { refTargetedElement.parentNode.removeChild(refTargetedElement); } if (child) { // A child was found insert the targeted element before said child group.insertBefore(refTargetedElement, child); } else { // A child was not found just append the element to the group group.appendChild(refTargetedElement); } } // Prevent default action if (e && e.preventDefault) { e.preventDefault(); } else { window.event.returnValue = false; } return false; } function mousedownListener(e) { if (mousedown || !moduleEnabled) return; e = e || window.event; var targetedElement = e.target; while (targetedElement) { if (!targetedElement.parentNode) return; // Targeted element not in a container // Is the targeted element a child of groupElements // and if so then we break out of this loop if (utils.inArray(groupElements, targetedElement.parentNode)) { break; } // The desired element is a child to one of the containers. targetedElement = targetedElement.parentNode; } mousedown = true; // Relative position to targeted element var absolutePosition = utils.getAbsolutePosition(targetedElement); relativeMousePosition = { x: e.pageX - absolutePosition.x, y: e.pageY - absolutePosition.y }; // Create the moveable element var moveableElement = createMoveableElement(targetedElement); // Make the targeted element invisible ytcenter.utils.addClass(targetedElement, "placementsystem-target"); //targetedElement.style.visibility = "hidden"; // Store two references for later use refMoveableElement = moveableElement; refTargetedElement = targetedElement; document.body.appendChild(moveableElement); // Add mouseup, mousemove, touchend and touchmove event listener utils.addEventListener(document, "mousemove", mousemoveListener, false); utils.addEventListener(document, "touchmove", mousemoveListener, false); // Prevent default action if (e && e.preventDefault) { e.preventDefault(); } else { window.event.returnValue = false; } return false; } function mouseupListener(e) { if (!mousedown || !moduleEnabled || !refTargetedElement) return; mousedown = false; e = e || window.event; // Make the targeted element visible ytcenter.utils.removeClass(refTargetedElement, "placementsystem-target"); //refTargetedElement.style.visibility = ""; // Remove the moveable element from the DOM refMoveableElement.parentNode.removeChild(refMoveableElement); // Remove relative mouse position relativeMousePosition = null; // Remove stored references refMoveableElement = null; refTargetedElement = null; // Remove mousemove and touchmove event listener utils.removeEventListener(document, "mousemove", mousemoveListener, false); utils.removeEventListener(document, "touchmove", mousemoveListener, false); // Prevent default action if (e && e.preventDefault) { e.preventDefault(); } else { window.event.returnValue = false; } return false; } function setGroupElements(groups) { groupElements = groups; } function setMoveableElementPosition(el, moveableElement) { var absolutePosition = utils.getAbsolutePosition(el); // Give the moveable an absolute position, which will be // on top of the original element. moveableElement.style.position = "absolute"; moveableElement.style.top = absolutePosition.y + "px"; moveableElement.style.left = absolutePosition.x + "px"; moveableElement.style.zIndex = "1999999999999"; } function createMoveableElement(el) { function removeTooltip(el) { // Removes tooltip from element el.title = ""; el.setAttribute("data-button-action", ""); el.setAttribute("data-tooltip-text", ""); ytcenter.utils.removeClass(el, "yt-uix-tooltip"); // Removes tooltip from children var children = el.children; for (var i = 0, len = children.length; i < len; i++) { removeTooltip(children[i]); } } var moveableElement = el.cloneNode(true); // Move the moveable element on top of the targeted element setMoveableElementPosition(el, moveableElement); // Removes tooltip from the moveable element removeTooltip(moveableElement); return moveableElement; } function setEnabled(enabled) { moduleEnabled = enabled; utils.removeEventListener(document, "mousemove", mousemoveListener, false); utils.removeEventListener(document, "touchmove", mousemoveListener, false); utils.removeEventListener(document, "mousedown", mousedownListener, false); utils.removeEventListener(document, "touchstart", mousedownListener, false); utils.removeEventListener(document, "mouseup", mouseupListener, false); utils.removeEventListener(document, "touchend", mouseupListener, false); if (enabled) { utils.addEventListener(document, "mousedown", mousedownListener, false); utils.addEventListener(document, "touchstart", mousedownListener, false); utils.addEventListener(document, "mouseup", mouseupListener, false); utils.addEventListener(document, "touchend", mouseupListener, false); } } // Reference to ytcenter.utils var utils = ytcenter.utils; /** * An array of where the moveable elements can be placed in. * * @property groupElements * @type HTMLElement[] **/ var groupElements = [ ]; // A reference to the moveable and targeted elements for use in mousemove var relativeMousePosition = null; var refMoveableElement = null; var refTargetedElement = null; // Properties var moduleEnabled = false; var mousedown = false; // Throttle the listener as it can be taxing for the users system. mousemoveListener = utils.throttle(mousemoveListener, 50); var exports = {}; exports.setGroupElements = setGroupElements; exports.setEnabled = setEnabled; // Add mousedown, touchstart, mouseup and touchend event listener utils.addEventListener(document, "mousedown", mousedownListener, false); utils.addEventListener(document, "touchstart", mousedownListener, false); utils.addEventListener(document, "mouseup", mouseupListener, false); utils.addEventListener(document, "touchend", mouseupListener, false); global[propertyName] = exports; })(ytcenter, "placementdragdrop"); /** * Dynamic element placement library **/ (function(global, propertyName){ /** * Adding an element to a defined group. * * @param {String} id The id of the group. * @param {HTMLElement} element The element that will be added to the group. **/ function addElement(id, elementId, element) { if (!groups[id]) throw "Group " + id + " has not been created!"; groups[id].children.push({ id: elementId, element: element }); // Append the element to the group element groups[id].element.appendChild(element); } /** * Creating a group. * * @param {String} id The id of the group. * @param {HTMLElement} element The group element. * @param {Object} options The options for the group. **/ function createGroup(id, element, options) { if (groups[id]) throw "Group " + id + " has already been created!"; groups[id] = { element: element, // The container element where the children resides options: options, // The options for that specific group children: [] }; } /** * Returns the unique ID for the given element. * * @param {HTMLElement} element The element to get the element from. * @return {String} The unique ID for the element. **/ function getElementUniqueId(element) { var classes = utils.listClass(element); for (var i = 0, len = classes.length; i < len; i++) { if (classes[i] !== "") { classes[i] = encodeURIComponent(classes[i]); } } if (classes.length > 0) { classes = "." + classes.join("."); if (classes[classes.length - 1] === ".") { classes = classes.substring(0, classes.length - 1); } } else { classes = ""; } var id = element.getAttribute("id"); if (id) { id = "#" + encodeURIComponent(id); } else { id = ""; } var tagName = encodeURIComponent(element.tagName); var uid = null; var parent = element.parentNode && element.parentNode instanceof HTMLElement; if (!id && !classes && parent) { var parentNode = element.parentNode; for (var i = 0, len = parentNode.children.length; i < len; i++) { if (parentNode.children[i] === element) { uid = tagName + "[" + i + "]" break; } } } else { uid = tagName + id + classes; } if (!id && parent) { return getElementUniqueId(element.parentNode) + " " + uid; } else { return uid; } } /** * Returns the HTMLElement with a specific unique ID. * * @param {String} id The unique ID. * @return {HTMLElement} The element with the unique ID. **/ function getElementByUniqueId(uid) { var tokens = uid.split(" "); var element = null; for (var i = 0, len = tokens.length; i < len; i++) { var match = /([a-zA-Z0-9_%\-]+)(\[[0-9]+\])?(\#[a-zA-Z0-9_%\-]+)?((\.[a-zA-Z0-9_%\-]+)*)/g.exec(tokens[i]); var tagName = decodeURIComponent(match[1]); var childIndex = null; if (match[2]) { childIndex = parseInt(match[2].substring(1, match[2].length - 1), 10); } var id = null; if (match[3]) { id = decodeURIComponent(match[3].substring(1)); } var classes = []; if (match[4]) { classes = match[4].substring(1).split("."); } for (var j = 0, lenj = classes.length; j < lenj; j++) { classes[j] = decodeURIComponent(classes[j]); } var doc = document; if (element) { doc = element; } var continues = false; if (id) { element = document.getElementById(id); } else if (classes.length > 0) { var elements = doc.getElementsByClassName(classes.join(" ")); for (var j = 0, lenj = elements.length; j < lenj; j++) { if (elements[j].tagName.toLowerCase() === tagName.toLowerCase()) { element = elements[j]; continues = true; break; } } if (!continues) return null; } else if (typeof childIndex === "number") { var elements = doc.getElementsByTagName(tagName); for (var j = 0, lenj = elements.length; j < lenj; j++) { if (elements[j] && elements[j].parentNode && elements[j].parentNode instanceof HTMLElement && elements[j].parentNode.children[childIndex] === elements[j]) { element = elements[j]; continues = true; break; } } if (!continues) return null; } else { element = doc.getElementsByTagName(tagName)[0]; } if (!element) { return null; } } return element; } function getRegisteredElementUniqueId(el) { for (var key in groups) { if (groups.hasOwnProperty(key)) { var children = groups[key].children; for (var i = 0, len = children.length; i < len; i++) { if (el === children[i].element) { return children[i].id; } } } } return null; } function getRegisteredElementByUniqueId(id) { for (var key in groups) { if (groups.hasOwnProperty(key)) { var children = groups[key].children; for (var i = 0, len = children.length; i < len; i++) { if (id === children[i].id) { return children[i].element; } } } } return null; } function isElementRegistered(el) { for (var id in groups) { if (groups.hasOwnProperty(id)) { if (isElementInGroup(el, id)) { return true; } } } return false; } function isElementInGroup(el, groupId) { //if (!groups[groupId]) throw "Group " + groupId + " does not exist!"; if (!groups[groupId]) return false; var children = groups[groupId].children; for (var i = 0, len = children.length; i < len; i++) { if (children[i].element === el) { return true; } } return false; } function createReferenceList() { var map = {}; for (var key in groups) { if (groups.hasOwnProperty(key)) { var group = groups[key]; var groupElements = []; var el = group.element; if (el && el.children) { var children = el.children; for (var i = 0, len = children.length; i < len; i++) { var child = children[i]; var data = { }; if (isElementRegistered(child)) { data.type = REGISTERED; data.uniqueId = getRegisteredElementUniqueId(child); data.element = child; } else { data.type = NONREGISTERED; data.uniqueId = getElementUniqueId(child); data.element = child; } groupElements.push(data); } } map[key] = groupElements; } } return map; } function getReferencedUniqueId(child, reference) { if (!reference) return null; for (var key in reference) { if (reference.hasOwnProperty(key)) { var group = reference[key]; for (var i = 0, len = group.length; i < len; i++) { if (child === group[i].element) { return group[i].uniqueId; } } } } return null; } function getReferencedElement(id, reference) { if (!reference) return null; for (var key in reference) { if (reference.hasOwnProperty(key)) { var group = reference[key]; for (var i = 0, len = group.length; i < len; i++) { if (id === group[i].uniqueId) { return group[i].element; } } } } return null; } function getSortList(referenceList) { var map = {}; for (var key in groups) { if (groups.hasOwnProperty(key)) { var group = groups[key]; var groupElements = []; var el = group.element; if (el && el.children) { var children = el.children; for (var i = 0, len = children.length; i < len; i++) { var child = children[i]; var data = { }; if (isElementRegistered(child)) { data.type = REGISTERED; data.uniqueId = getRegisteredElementUniqueId(child); } else { data.type = NONREGISTERED; data.uniqueId = getReferencedUniqueId(child, referenceList) || getElementUniqueId(child); } groupElements.push(data); } } map[key] = groupElements; } } return map; } function setSortList(list, referenceList) { utils.each(list, function(groupId, elements){ if (!groups[groupId]) con.warn("Group " + groupId + " does not exist!"); var group = groups[groupId]; for (var i = 0, len = elements.length; i < len; i++) { var element = elements[i]; var el = null; if (element.type === REGISTERED) { el = getRegisteredElementByUniqueId(element.uniqueId); } else if (element.type === NONREGISTERED) { el = getReferencedElement(element.uniqueId, referenceList) || getElementByUniqueId(element.uniqueId); } if (el !== null) { if (el.parentNode) { el.parentNode.removeChild(el); } group.element.appendChild(el); } else { con.warn("Unknown element in settings", element); } } }); } function setMoveable(enabled) { ytcenter.placementdragdrop.setGroupElements(getGroupElements()); ytcenter.placementdragdrop.setEnabled(enabled); } function getGroupElements() { var groupElements = []; for (var key in groups) { if (groups.hasOwnProperty(key)) { groupElements.push(groups[key].element); } } return groupElements; } function clearGroups() { groups = {}; } /* Easier access to ytcenter.utils */ var utils = ytcenter.utils; var REGISTERED = 0; var NONREGISTERED = 1; var groups = {}; var exports = {}; /* Make the API public */ exports.setMoveable = setMoveable; exports.addElement = addElement; exports.createGroup = createGroup; exports.getSortList = getSortList; exports.setSortList = setSortList; exports.createReferenceList = createReferenceList; exports.clearGroups = clearGroups; global[propertyName] = exports; })(ytcenter, "placementsystem"); (function(global, propertyName){ function createOverlay() { var overlay = document.createElement("div"); overlay.className = "element-focus-overlay"; return overlay; } function focus(target, saveFunc, cancelFunc) { var replacementHolder = document.createElement("div"); replacementHolder.style.height = target.offsetHeight + "px"; var targetPos = utils.getAbsolutePosition(target); var targetWidth = target.offsetWidth; var targetHeight = target.offsetHeight; // Eclipse math //var sqrt2 = Math.sqrt(2); //var paddTop = targetHeight/sqrt2 - targetHeight/2 + 10; //var paddLeft = targetWidth/sqrt2 - targetWidth/2 + 10; // Box math var paddTop = 15; var paddLeft = 15; target.parentNode.replaceChild(replacementHolder, target); var wrapper = document.createElement("div"); wrapper.className = "element-focus-wrapper"; wrapper.style.top = (targetPos.y - paddTop) + "px"; wrapper.style.left = (targetPos.x - paddLeft) + "px"; var focusEl = document.createElement("div"); focusEl.className = "element-focus"; focusEl.style.padding = paddTop + "px " + paddLeft + "px"; focusEl.style.width = targetWidth + "px"; wrapper.appendChild(focusEl); var focusContainer = document.createElement("div"); focusContainer.className = "element-focus-container"; focusEl.appendChild(focusContainer); focusContainer.appendChild(target); var btnWrapper = document.createElement("div"); btnWrapper.className = "element-focus-btn-wrapper"; var labelSave = ytcenter.gui.createYouTubeButtonTextLabel("BTN_APPLY"); var btnSave = ytcenter.gui.createYouTubePrimaryButton("", [ labelSave ]); btnSave.addEventListener("click", saveFunc, false); var labelCancel = ytcenter.gui.createYouTubeButtonTextLabel("BTN_CANCEL"); var btnCancel = ytcenter.gui.createYouTubeDefaultButton("", [ labelCancel ]); btnCancel.addEventListener("click", cancelFunc, false); btnWrapper.appendChild(btnSave); btnWrapper.appendChild(btnCancel); wrapper.appendChild(btnWrapper); var overlay = createOverlay(); document.body.appendChild(overlay); document.body.appendChild(wrapper); var oldScroll = ytcenter.utils.scrollTop(); var viewPort = ytcenter.utils.getViewPort(); console.log(oldScroll, viewPort, targetPos); ytcenter.utils.scrollTop(targetPos.y - (viewPort.height - wrapper.offsetHeight)/2); //ytcenter.utils.addClass(document.body, "ytcenter-dialog-active"); return function(){ //ytcenter.utils.removeClass(document.body, "ytcenter-dialog-active"); ytcenter.utils.scrollTop(oldScroll); target.parentNode.removeChild(target); replacementHolder.parentNode.replaceChild(target, replacementHolder); overlay.parentNode.removeChild(overlay); wrapper.parentNode.removeChild(wrapper); }; } var utils = ytcenter.utils; var exports = {}; exports.focus = focus; global[propertyName] = exports; })(ytcenter, "elementfocus"); ytcenter.descriptionTags = (function(){ function addTags(list, tags) { for (var i = 0, len = tags.length; i < len; i++) { var item = document.createElement("li"); item.textContent = tags[i]; list.appendChild(item); } } function addSection(title, tags) { if (addedSections[title]) { addedSections[title].innerHTML = ""; addTags(addedSections[title], tags); return; } var extras = document.getElementById("watch-description-extras"); if (extras) { var list = extras.getElementsByClassName("watch-extras-section"); if (list && list[0]) { var item = document.createElement("li"); item.className = "watch-meta-item yt-uix-expander-body"; var titleElement = document.createElement("h4"); titleElement.className = "title"; titleElement.textContent = ytcenter.language.getLocale(title); ytcenter.events.addEvent("language-refresh", function(){ titleElement.textContent = ytcenter.language.getLocale(title); }); var tagList = document.createElement("ul"); tagList.className = "content watch-info-tag-list"; addedSections[title] = tagList; addTags(tagList, tags); item.appendChild(titleElement); item.appendChild(tagList); elements.push(item); list[0].appendChild(item); } } } function destroy() { for (var i = 0, len = elements.length; i < len; i++) { var element = elements[i]; if (element.parentNode && element.parentNode.removeChild) { element.parentNode.removeChild(element); } } addedSections = {}; elements = []; } var addedSections = {}; var elements = []; var exports = {}; exports.addSection = addSection; exports.destroy = destroy; return exports; })(); ytcenter.language = (function(){ function __setElementText(lang, elm, name, type, replace) { if (type.indexOf("@") === 0) { elm[type.substring(1)] = ytcenter.utils.replaceTextAsString(lang[name], replace); } else { elm.setAttribute(type, ytcenter.utils.replaceTextAsString(lang[name], replace)); } } var db = []; var currentLang = {}; var defaultLang = "en-US"; var exports = {}; /** * Adds an element to the database which will then be updated when the update function is called. * @elm The element which will get the update. * @name The locale name which will be used to update the text. * @type The type of how the element will be manipulated. If there's an @ followed by textContent it will update the textContent or else it's an argument. */ exports.addLocaleElement = function(elm, name, type, replace) { replace = replace || {}; db.push([elm, name, type, replace]); }; exports.getLanguage = function(language){ return ytcenter.languages[language]; }; /** * Gets the locale for the specific locale name. */ exports.getLocale = function(name, language){ if (!currentLang) currentLang = exports.getLanguage(defaultLang); if (typeof language !== "string" && currentLang.hasOwnProperty(name)) { return currentLang[name]; } else if (ytcenter.languages.hasOwnProperty(language)) { return exports.getLanguage(language)[name]; } else { return null; } }; /** * Updates all elements added to the database with the given language. * @lang The array with the specific language data. */ exports.update = function(lang, doNotRecurse){ lang = lang || ytcenter.settings.language; if (lang === "auto") { if (uw.yt && uw.yt.getConfig && uw.yt.getConfig("PAGE_NAME")) { if (uw.yt.config_.FEEDBACK_LOCALE_LANGUAGE && ytcenter.languages.hasOwnProperty(uw.yt.config_.FEEDBACK_LOCALE_LANGUAGE)) { lang = uw.yt.config_.FEEDBACK_LOCALE_LANGUAGE; } else if (uw.yt.config_.SANDBAR_LOCALE && ytcenter.languages.hasOwnProperty(uw.yt.config_.SANDBAR_LOCALE)) { lang = uw.yt.config_.SANDBAR_LOCALE; } else if (uw.yt.config_.HL_LOCALE && ytcenter.languages.hasOwnProperty(uw.yt.config_.HL_LOCALE)) { lang = uw.yt.config_.HL_LOCALE; } else { lang = defaultLang; } } else { lang = defaultLang; if (!doNotRecurse) { con.log("Language set to " + lang + " because it could not be auto-detected yet"); var languageUpdateCounter = 0; var languageUpdateInterval = uw.setInterval((function(){ if (uw.yt && uw.yt.getConfig && uw.yt.getConfig("PAGE_NAME")) { uw.clearInterval(languageUpdateInterval); ytcenter.language.update("auto", true); } else if (++languageUpdateCounter >= 100) { uw.clearInterval(languageUpdateInterval); con.log("YouTube configuration data is inaccessible; giving up on language auto-detection."); } }).bind(this), 500); } else { con.log("Language set to " + lang + " because auto-detection failed unexpectedly"); } } } if (!ytcenter.languages[lang]) lang = defaultLang; currentLang = ytcenter.languages[lang]; for (var i = 0; i < db.length; i++) { __setElementText(currentLang, db[i][0], db[i][1], db[i][2], db[i][3]); } ytcenter.events.performEvent("language-refresh"); //ytcenter.events.performEvent("settings-update"); }; return exports; })(); ytcenter.languages = ytcenter_locales; ytcenter._settings = { videoThumbnailQualityFPS: true, enableComments: true, channelUploadedVideosPlaylist: false, ytOnlyStageMode: false, playerGlowEffectOnPlayer: "both", bufferEnabled: false, bufferSize: 569228273678, embedBufferEnabled: false, embedBufferSize: 569228273678, channelBufferEnabled: false, channelBufferSize: 569228273678, playlistAutoPlay: true, playlistAutoPlayFreeze: false, /* Freeze the playlist auto play so that playlistAutoPlay is not changed when the toggle button has been clicked */ playerGlowEnabled: false, playerGlowPixelInterval: 100, playerGlowRequestAnimationFrame: true, playerGlowUpdateInterval: 20, playerGlowTransition: 0, playerGlowBlur: 15, playerGlowSpread: 5, playerGlowOpacity: 75, playerGlowFactor: 50, playerMultiGlowEffect: true, playerMultiGlowEffectDepth: 10, playerMultiGlowEffectBlockInterval: 5, likeButtonColor: "#000000", likeButtonHoverColor: "#000000", dislikeButtonColor: "#000000", dislikeButtonHoverColor: "#000000", likedButtonColor: "#2793e6", likedButtonHoverColor: "#2793e6", dislikedButtonColor: "#000000", dislikedButtonHoverColor: "#000000", likeButtonOpacity: 60, likeButtonHoverOpacity: 70, dislikeButtonOpacity: 60, dislikeButtonHoverOpacity: 70, likedButtonOpacity: 80, likedButtonHoverOpacity: 100, dislikedButtonOpacity: 80, dislikedButtonHoverOpacity: 100, enable_custom_fexp: false, custom_fexp: "", hideLangAlert: true, staticHeader_scrollToPlayer: false, staticHeader: false, debugConsole: true, // Saves the content of the console for the debug log. gridCollectionPage: true, logoLink: "/", hideRecommendedChannels: false, repeatShowText: true, enableYouTubeShortcuts: true, disableFeedItemActionMenu: false, disableGuideCount: false, YouTubeExperiments: [], headlineTitleExpanded: false, videoThumbnailQualitySeparated: true, embedWriteEmbedMethodReloadDelay: 1000, embedWriteEmbedMethod: "test5", // "standard", "test1", "test2", "test3", "standard+reload", "test1+reload", "test2+reload", "test3+reload", "test4", "test5" fixHTML5Annotations: false, saveErrorStatusTimeout: 5000, saveStatusTimeout: 2000, flexWidthOnChannelPage: true, playerDarkSideBGRetro: false, playerDarkSideBGColor: "#1b1b1b", playerDarkSideBG: false, useSecureProtocol: true, videoThumbnailRatingsBarHeight: 2, sparkbarHeight: 2, sparkbarLikesColor: "#590", sparkbarDislikesColor: "#ccc", commentsPlusLinkRedirectConfirm: true, commentsPlusScrollToCommentAtCollapse: true, commentsPlusRemoveLinks: false, commentsPlusBlacklist: [ { type: "equals", length: 1 }, { type: "repeat", amount: 9 }, { type: "profilelinks", regex: "${username}", attr: "textContent" }, { type: "hashlinks", regex: "fixyoutube", attr: "textContent" } ], commentsPlusWhitelist: [], likeSwitchToTab: "none", // none, share, stats, report, login, ratings-disabled, rental-required, error endOfVideoAutoSwitchToTab: "none", // none, share, stats, report, login, ratings-disabled, rental-required, error //enableYouTubeAutoSwitchToShareTab: false, topScrollPlayerEnabled: false, topScrollPlayerActivated: false, topScrollPlayerExitOnVideoEnd: false, topScrollPlayerEnterOnVideoPlay: false, topScrollPlayerExitOnVideoPause: false, topScrollPlayerTimesToEnter: 1, topScrollPlayerTimesToExit: 0, topScrollPlayerCountIncreaseBefore: true, topScrollPlayerHideScrollbar: false, topScrollPlayerBumpTimer: 2000, topScrollPlayerAnimation: true, topScrollPlayerEnabledOnlyVideoPlaying: true, topScrollPlayerScrollUpToExit: false, debug_settings_playersize: false, debug_settings_buttonPlacement: false, debug_settings_videoThumbnailData: false, debug_settings_commentCountryData: false, debug_settings_watchedVideos: false, debug_settings_notwatchedVideos: false, debug_playervars: false, debug_spf_args: false, signatureDecipher: [], embed_defaultAutoplay: true, hideTicker: true, enableEndscreenAutoplay: false, removeYouTubeTitleSuffix: true, playerPlayingTitleIndicator: false, playerOnlyOneInstancePlaying: true, videoThumbnailAnimationEnabled: true, videoThumbnailAnimationShuffle: false, videoThumbnailAnimationDelay: 1000, videoThumbnailAnimationInterval: 700, videoThumbnailAnimationFallbackInterval: 2000, forcePlayerType: "default", // default, flash, html5, aggressive_flash embed_forcePlayerType: "default", // default, flash, html5, aggressive_flash channel_forcePlayerType: "default", // default, flash, html5, aggressive_flash settingsDialogMode: true, ytExperimentFixedTopbar: false, ytspf: false, videoThumbnailCacheSize: 500, commentCacheSize: 500, watchedVideosIndicator: true, hideWatchedVideos: false, watchedVideos: [], notwatchedVideos: [], watchedVideosLimit: 10000, // Hope this isn't too big. notwatchedVideosLimit: 10000, // Hope this isn't too big. gridSubscriptionsPage: true, compatibilityCheckerForChromeDisable: false, removeRelatedVideosEndscreen: false, enableResize: true, guideMode: "default", // [default, always_open, always_closed] uploaderCountryEnabled: true, uploaderCountryShowFlag: true, uploaderCountryUseNames: true, uploaderCountryPosition: "after_username", // ["before_username", "after_username", "last"] commentCountryData: [], commentCountryEnabled: true, commentCountryShowFlag: true, commentCountryUseNames: true, commentCountryLazyLoad: true, commentCountryButtonLoad: true, commentCountryPosition: "after_username", // ["before_username", "after_username", "last"] videoThumbnailData: [], videoThumbnailQualityBar: true, videoThumbnailQualityPosition: "topleft", videoThumbnailQualityDownloadAt: "hover_thumbnail", videoThumbnailQualityVisible: "always", videoThumbnailRatingsBar: true, videoThumbnailRatingsBarPosition: "bottom", videoThumbnailRatingsBarDownloadAt: "scroll_into_view", videoThumbnailRatingsBarVisible: "always", videoThumbnailRatingsBarLikesColor: "#590", videoThumbnailRatingsBarDislikesColor: "#f00", videoThumbnailRatingsCount: true, videoThumbnailRatingsCountPosition: "bottomleft", videoThumbnailRatingsCountDownloadAt: "scroll_into_view", videoThumbnailRatingsCountVisible: "show_hover", videoThumbnailWatchLaterPosition: "bottomright", videoThumbnailWatchLaterVisible: "show_hover", videoThumbnailTimeCodePosition: "bottomright", videoThumbnailTimeCodeVisible: "hide_hover", dashPlayback: true, embed_dashPlayback: true, channel_dashPlayback: true, language: 'auto', filename: '{title}', fixfilename: false, flexWidthOnPage: true, enableAutoVideoQuality: true, autoVideoQuality: 'hd720', removeAdvertisements: true, preventAutoPlay: false, preventAutoBuffer: false, preventTabAutoPlay: false, preventTabAutoBuffer: false, preventTabPlaylistAutoPlay: false, preventTabPlaylistAutoBuffer: false, preventPlaylistAutoPlay: false, preventPlaylistAutoBuffer: false, scrollToPlayer: true, expandDescription: false, enableAnnotations: true, //enableCaptions: true, // % enableShortcuts: true, autohide: '-1', enableVolume: false, volume: 100, mute: false, enableDownload: true, downloadQuality: 'highres', downloadFormat: 'mp4', downloadAsLinks: true, show3DInDownloadMenu: false, enableRepeat: true, repeatSave: false, autoActivateRepeat: false, mp3Services: '', lightbulbEnable: true, lightbulbBackgroundColor: '#000000', lightbulbBackgroundOpaque: 95, lightbulbClickThrough: false, lightbulbAutoOff: false, flashWMode: 'none', // none, window, direct, opaque, transparent, gpu playerTheme: 'dark', // dark, light playerColor: 'red', // red, white enableUpdateChecker: true, updateCheckerInterval: "0", updateCheckerLastUpdate: 0, channel_enableAutoVideoQuality: true, channel_autoVideoQuality: "medium", channel_autohide: "-1", channel_playerTheme: "dark", channel_playerColor: "red", channel_flashWMode: "none", channel_enableAnnotations: true, channel_preventAutoPlay: false, channel_preventAutoBuffer: true, channel_enableVolume: false, channel_volume: 100, channel_mute: false, channel_experimentalFlashMode: "clone", channel_experimentalHTML5Mode: "none", embed_enabled: true, embed_enableAutoVideoQuality: true, embed_autoVideoQuality: "medium", embed_autohide: "-1", embed_playerTheme: "dark", embed_playerColor: "red", embed_flashWMode: "none", embed_enableAnnotations: true, embed_preventAutoPlay: false, embed_preventAutoBuffer: true, embed_enableVolume: false, embed_volume: 100, embed_mute: false, resizeEnable: true, resizeSave: false, aspectEnable: true, aspectSave: false, aspectValue: "default", repeatShowIcon: true, watch7playerguidehide: false, watch7playerguidealwayshide: false, removeBrandingBanner: true, removeBrandingBackground: true, removeBrandingWatermark: true, fixGuideNotVisible: false, hideFeedbackButton: false, bgcolor: "default", embed_bgcolor: "default", channel_bgcolor: "default", player_wide: false, "resize-default-playersize": "default", "resize-small-button": "default_fit_to_content", "resize-large-button": "default_720", "playerSizeAspect": "16:9", // default, 4:3, 3:2, 5:4, 16:9, 16:10, 24:10 "resize-playersizes": [ { id: "default_small", config: { width: "", height: "", large: false, align: true, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_large", config: { width: "", height: "", large: true, align: true, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_fit_to_content", config: { customName: "Fit to Content", width: "1040px", height: "", large: true, align: true, scrollToPlayer: false, scrollToPlayerButton: false, } }, { id: "default_collapse_player", config: { customName: "Collapse The Player", width: "640px", height: "0px", large: false, align: true, scrollToPlayer: false, scrollToPlayerButton: false, } }, { id: "default_720", config: { customName: "720p", width: "1280px", height: "", large: true, align: false, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_1080", config: { customName: "1080p", width: "1920px", height: "", large: true, align: false, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_70_percent", config: { customName: "70%", width: "70%", height: "", large: true, align: false, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_80_percent", config: { customName: "80%", width: "80%", height: "", large: true, align: false, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_90_percent", config: { customName: "90%", width: "90%", height: "", large: true, align: false, scrollToPlayer: false, scrollToPlayerButton: false } }, { id: "default_100_percent", config: { customName: "Fill", width: "100%", height: "100%", large: true, align: false, scrollToPlayer: true, scrollToPlayerButton: true } } ] }; ytcenter.settings = $Clone(ytcenter._settings); ytcenter.doRepeat = false; ytcenter.html5 = false; ytcenter.html5flash = false; ytcenter.watch7 = true; ytcenter.redirect = function(url, newWindow){ con.log("Redirecting" + (newWindow ? " in new window" : "") + " to " + url); if (typeof newWindow != "undefined") { window.open(ytcenter.utils.replaceTextAsString(url, { title: ytcenter.video.title, videoid: ytcenter.video.id, author: ytcenter.video.author, url: loc.href })); } else { loc.href = ytcenter.utils.replaceTextAsString(url, { title: ytcenter.video.title, videoid: ytcenter.video.id, author: ytcenter.video.author, url: loc.href }); } }; ytcenter.discardElement = function(element){ if (element.parentNode && typeof element.parentNode.removeChild === "function") { element.parentNode.removeChild(element); } }; ytcenter.callback_db = []; if (identifier === 3) { // Firefox Extension self.port.on("xhr onreadystatechange", function(data){ var data = JSON.parse(data); if (ytcenter.callback_db[data.id].onreadystatechange) ytcenter.callback_db[data.id].onreadystatechange({responseText: data.responseText}); }); self.port.on("xhr onload", function(data){ var data = JSON.parse(data); if (ytcenter.callback_db[data.id].onload) ytcenter.callback_db[data.id].onload({responseText: data.responseText}); }); self.port.on("xhr onerror", function(data){ var data = JSON.parse(data); if (ytcenter.callback_db[data.id].onerror) ytcenter.callback_db[data.id].onerror({responseText: data.responseText}); }); self.port.on("load callback", function(data){ data = JSON.parse(data); ytcenter.callback_db[data.id](data.storage); }); self.port.on("save callback", function(data){ data = JSON.parse(data); ytcenter.callback_db[data.id](); }); } ytcenter.storageName = "YouTubeCenterSettings"; ytcenter.loadSettings = function(callback){ if (preloadedSettings) { for (var key in preloadedSettings) { if (preloadedSettings.hasOwnProperty(key)) { ytcenter.settings[key] = preloadedSettings[key]; } } preloadedSettings = undefined; callback && callback(); } ytcenter.unsafeCall("load", [ytcenter.storageName], function(storage){ if (storage === "[object Object]") storage = {}; if (typeof storage === "string") storage = JSON.parse(storage); for (var key in storage) { if (storage.hasOwnProperty(key)) { ytcenter.settings[key] = storage[key]; } } if (callback) callback(); }); }; ytcenter.__settingsLoaded = false; ytcenter.loadSettings(function(){ ytcenter.__settingsLoaded = true; var page = ytcenter.getPage(); if ((ytcenter.settings.forcePlayerType === "aggressive_flash" && page === "watch") || (ytcenter.settings.embed_forcePlayerType === "aggressive_flash" && page === "embed") || (ytcenter.settings.channel_forcePlayerType === "aggressive_flash" && page === "channel")) { // Try to prevent the html5 player from having any effect on the page to increase the load time of the flash player. uw.yt = uw.yt || {}; uw.yt.player = uw.yt.player || {}; uw.yt.player.Application = uw.yt.player.Application || {}; uw.yt.player.Application.create = uw.yt.player.Application.create || null; freeze(uw, "yt.player.Application.create"); } settingsInit(); if ((ytcenter.getPage() === "embed" && ytcenter.settings.embed_enabled) || ytcenter.getPage() !== "embed") { ytcenter.tabEvents.addEventListener("settings", function(settings){ con.log("[Tab Events] Received updated settings from another tab."); var player_wide = ytcenter.settings.player_wide; // We don't want this to be updated. ytcenter.settings = JSON.parse(JSON.stringify(settings)); ytcenter.settings.player_wide = player_wide; ytcenter.language.update(); /*ytcenter.events.performEvent("settings-update"); ytcenter.title.update(); ytcenter.classManagement.applyClasses();*/ }); } }); ytcenter.saveSettings_timeout_obj = null; ytcenter.saveSettings_timeout = 300; ytcenter.saveSettings = (function(){ function save(throttle, callback) { if (typeof throttle !== "boolean") throttle = true; ytcenter.events.performEvent("save"); if (throttle) { throttleStoreSettings(callback); } else { storeSettings(callback); } } function saveComplete(callback) { ytcenter.events.performEvent("save-complete"); throttleAnnounceSettingStored(); // This should not be spammed! var args = Array.prototype.splice.call(arguments, 1, arguments.length); if (typeof callback === "function") callback.apply(null, args); } function storeSettings(callback) { con.log("[Storage] Saving Settings"); ytcenter.unsafeCall("save", [ytcenter.storageName, JSON.stringify(ytcenter.settings)], ytcenter.utils.bind(null, saveComplete, callback)); } function announceSettingStored() { con.log("[Tab Events] Sending new settings to other open tabs."); ytcenter.tabEvents.fireEvent("settings", ytcenter.settings); } var throttleStoreSettings = ytcenter.utils.throttle(storeSettings, 5000); var throttleAnnounceSettingStored = ytcenter.utils.throttle(announceSettingStored, 7500); return save; })(); ytcenter.checkForUpdatesDev = (function(){ var updElement; return function(success, error, disabled){ // We check if this build is a dev build. if (!devbuild) { con.log("[Update] This is not a dev build!"); return; } else { con.log("Checking for updates..."); if (typeof error == "undefined") { error = function(){}; } ytcenter.utils.xhr({ method: "GET", url: "https://raw.github.com/YePpHa/YouTubeCenter/master/devbuild.number", ignoreCache: true, headers: { "Content-Type": "text/plain" }, onload: (function(success){ return function(response){ con.log("Got Update Response"); var buildnumber = -1; if (response && response.responseText) { buildnumber = parseInt(/build\.number=([0-9]+)/m.exec(response.responseText)[1], 10); con.log("[Update] Current dev build #" + buildnumber + ". Your build number #" + devnumber); } else { con.log("Couldn't parse the build number"); } if (buildnumber > devnumber) { con.log("New update available"); if (typeof updElement != "undefined") { ytcenter.discardElement(updElement); } updElement = document.createElement("div"); updElement.className = "yt-alert yt-alert-default yt-alert-warn"; updElement.style.margin = "0 auto"; var ic = document.createElement("div"); ic.className = "yt-alert-icon"; var icon = document.createElement("img"); icon.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; icon.className = "icon master-sprite"; icon.setAttribute("alt", "Alert icon"); ic.appendChild(icon); updElement.appendChild(ic); var c = document.createElement("div"); c.className = "yt-alert-buttons"; var cbtn = document.createElement("button"); cbtn.setAttribute("type", "button"); cbtn.setAttribute("role", "button"); cbtn.setAttribute("onclick", ";return false;"); cbtn.className = "close yt-uix-close yt-uix-button yt-uix-button-close"; ytcenter.utils.addEventListener(cbtn, "click", (function(updElement){ return function(){ ytcenter.utils.addClass(updElement, 'hid'); }; })(updElement)); var cbtnt = document.createElement("span"); cbtnt.className = "yt-uix-button-content"; cbtnt.textContent = "Close "; cbtn.appendChild(cbtnt); c.appendChild(cbtn); updElement.appendChild(c); var cn = document.createElement("div"); cn.className = "yt-alert-content"; var cnt = document.createElement("span"); cnt.className = "yt-alert-vertical-trick"; var cnme = document.createElement("div"); cnme.className = "yt-alert-message"; var f1 = ytcenter.utils.replaceText(ytcenter.language.getLocale("UPDATER_DEV_NEWBUILD"), { "{lb}": function(){ return document.createElement("br"); }, "{url}": function(){ var a = document.createElement("a"); a.href = "https://github.com/YePpHa/YouTubeCenter/wiki/Developer-Version"; a.setAttribute("target", "_blank"); a.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("DEV_BUILD"), { "{n}": document.createTextNode(buildnumber) })); return a; } } ); ytcenter.events.addEvent("language-refresh", function(){ f1 = ytcenter.utils.replaceText(ytcenter.language.getLocale("UPDATER_DEV_NEWBUILD"), { "{lb}": function(){ return document.createElement("br"); }, "{url}": function(){ var a = document.createElement("a"); a.href = "https://github.com/YePpHa/YouTubeCenter/wiki/Developer-Version"; a.setAttribute("target", "_blank"); a.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("DEV_BUILD"), { "{n}": document.createTextNode(buildnumber) })); return a; } } ); cnme.innerHTML = ""; cnme.appendChild(f1); }); cnme.appendChild(f1); cn.appendChild(cnt); cn.appendChild(cnme); updElement.appendChild(cn); document.getElementById("alerts").appendChild(updElement); } else { con.log("No new updates available"); } if (success) { con.log("Calling update callback"); success(response); } }; })(success), onerror: error }); } }; })(); ytcenter.checkForUpdates = (function(){ var updElement; return function(success, error, disabled){ if (devbuild) { con.log("[Update] This is a dev build."); ytcenter.checkForUpdatesDev(success, error, disabled); // This is only called when it's a developer build. return; } // If it's the Chrome/Opera addon and the browser is Opera, or if it's the Firefox addon it will not check for updates! if ((identifier === 1 && (uw.navigator.userAgent.indexOf("Opera") !== -1 || uw.navigator.userAgent.indexOf("OPR/") !== -1)) || identifier === 6 || identifier === 8) { con.log("[UpdateChecker] UpdateChecker has been disabled!"); if (typeof disabled == "function") disabled(); } else { con.log("Checking for updates..."); if (typeof error == "undefined") { error = function(){}; } ytcenter.utils.xhr({ method: "GET", url: "https://yeppha.github.io/downloads/YouTubeCenter.meta.js", headers: { "Content-Type": "text/plain" }, onload: (function(success){ return function(response){ con.log("Got Update Response"); var rev = -1, ver = "-1" if (response && response.responseText) { rev = parseInt(/^\/\/ @updateVersion\s+([0-9]+)$/m.exec(response.responseText)[1], 10); ver = /^\/\/ @version\s+([a-zA-Z0-9.,-_]+)$/m.exec(response.responseText)[1]; } else { con.log("Couldn't parse revision and version from the update page."); } if (rev > ytcenter.revision) { con.log("New update available"); if (typeof updElement != "undefined") { ytcenter.discardElement(updElement); } updElement = document.createElement("div"); updElement.className = "yt-alert yt-alert-default yt-alert-warn"; updElement.style.margin = "0 auto"; var ic = document.createElement("div"); ic.className = "yt-alert-icon"; var icon = document.createElement("img"); icon.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; icon.className = "icon master-sprite"; icon.setAttribute("alt", "Alert icon"); ic.appendChild(icon); updElement.appendChild(ic); var c = document.createElement("div"); c.className = "yt-alert-buttons"; var cbtn = document.createElement("button"); cbtn.setAttribute("type", "button"); cbtn.setAttribute("role", "button"); cbtn.setAttribute("onclick", ";return false;"); cbtn.className = "close yt-uix-close yt-uix-button yt-uix-button-close"; ytcenter.utils.addEventListener(cbtn, "click", (function(updElement){ return function(){ ytcenter.utils.addClass(updElement, 'hid'); }; })(updElement)); var cbtnt = document.createElement("span"); cbtnt.className = "yt-uix-button-content"; cbtnt.textContent = "Close "; cbtn.appendChild(cbtnt); c.appendChild(cbtn); updElement.appendChild(c); var cn = document.createElement("div"); cn.className = "yt-alert-content"; var cnt = document.createElement("span"); cnt.className = "yt-alert-vertical-trick"; var cnme = document.createElement("div"); cnme.className = "yt-alert-message"; var f1 = document.createTextNode(ytcenter.language.getLocale("UPDATE_NOTICE")); ytcenter.language.addLocaleElement(f1, "UPDATE_NOTICE", "@textContent", {}); var f2 = document.createElement("br"); var f3 = document.createTextNode(ytcenter.language.getLocale("UPDATE_INSTALL")); ytcenter.language.addLocaleElement(f3, "UPDATE_INSTALL", "@textContent", {}); var f4 = document.createTextNode(" "); var f5 = document.createElement("a"); if (identifier === 0) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.user.js"; } else if (identifier === 1) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.crx"; } else if (identifier === 2) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.mxaddon"; } else if (identifier === 3) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.xpi"; } else if (identifier === 4) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.safariextz"; } else if (identifier === 5) { f5.href = "https://yeppha.github.io/downloads/YouTubeCenter.oex"; } f5.setAttribute("target", "_blank"); f5.textContent = "YouTube Center v" + ver; var f6 = document.createTextNode(" "); var f7 = document.createTextNode(ytcenter.language.getLocale("UPDATE_OR")); ytcenter.language.addLocaleElement(f7, "UPDATE_OR", "@textContent", {}); var f8 = document.createTextNode(" "); var f9 = document.createElement("a"); f9.setAttribute("target", "_blank"); if (identifier === 6) { f9.href = "https://addons.mozilla.org/en-us/firefox/addon/youtube-center/"; f9.textContent = "addons.mozilla.org"; } else { f9.href = "https://github.com/YePpHa/YouTubeCenter/wiki"; f9.textContent = "github.com/YePpHa/YouTubeCenter/"; } cnme.appendChild(f1); cnme.appendChild(f2); cnme.appendChild(f3); cnme.appendChild(f4); cnme.appendChild(f5); cnme.appendChild(f6); cnme.appendChild(f7); cnme.appendChild(f8); cnme.appendChild(f9); cn.appendChild(cnt); cn.appendChild(cnme); updElement.appendChild(cn); document.getElementById("alerts").appendChild(updElement); } else { con.log("No new updates available"); } if (success) { con.log("Calling update callback"); success(response); } }; })(success), onerror: error }); } }; })(); ytcenter.mp3services = [ { label: 'SETTINGS_MP3SERVICES_VIDEO2MP3', value: 'http://www.video2mp3.net/index.php?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&hq=0' }, { label: 'SETTINGS_MP3SERVICES_VIDEO2MP3_HQ', value: 'http://www.video2mp3.net/index.php?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&hq=1' }, { label: 'SETTINGS_MP3SERVICES_YOUTUBEINMP3_64', value: 'http://www.youtubeinmp3.com/download.php?youtubeURL=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&quality=64&submit=Download+MP3' }, { label: 'SETTINGS_MP3SERVICES_YOUTUBEINMP3_128', value: 'http://www.youtubeinmp3.com/download.php?youtubeURL=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&quality=128&submit=Download+MP3' }, { label: 'SETTINGS_MP3SERVICES_YOUTUBEINMP3_320', value: 'http://www.youtubeinmp3.com/download.php?youtubeURL=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&quality=320&submit=Download+MP3' }, { label: 'SETTINGS_MP3SERVICES_HDDOWNLOADER_128', value: 'http://www.hddownloader.com/index.php?act=do&url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&dldtype=128&outFormat=mp3' }, { label: 'SETTINGS_MP3SERVICES_HDDOWNLOADER_192', value: 'http://www.hddownloader.com/index.php?act=do&url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&dldtype=192&outFormat=mp3' }, { label: 'SETTINGS_MP3SERVICES_HDDOWNLOADER_256', value: 'http://www.hddownloader.com/index.php?act=do&url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}&dldtype=256&outFormat=mp3' }, { label: 'SETTINGS_MP3SERVICES_YOUTUBEMP3PRO', value: 'http://www.youtubemp3pro.com/#{videoid}' }, { label: 'SETTINGS_MP3SERVICES_YOUTUBEMP3', value: 'http://www.youtube-mp3.org/#v={videoid}' }, { label: 'SETTINGS_MP3SERVICES_SNIPMP3', value: 'http://snipmp3.com/?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}' }, { label: 'SETTINGS_MP3SERVICES_CLIPCONVERTER', value: 'http://www.clipconverter.cc/?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D{videoid}' } ]; ytcenter.settingsPanel = (function(){ var a = {}, categories = [], subcategories = [], options = []; a.createCategory = function(label){ var id = categories.length; categories.push({ id: id, label: label, enabled: true, visible: true, subcategories: [] }); return a.getCategory(id); }; a.createSubCategory = function(label){ var id = subcategories.length; subcategories.push({ id: id, label: label, enabled: true, visible: true, options: [], listeners: {} }); return a.getSubCategory(id); }; a.createOption = function(defaultSetting, module, label, args, help){ var id = options.length; options.push({ id: id, label: label, args: args, defaultSetting: defaultSetting, module: module, help: help, enabled: true, visible: true, styles: {}, moduleStyles: {}, listeners: {} }); return a.getOption(id); }; a.getCategory = function(id){ if (categories.length <= id || id < 0) throw new Error("[Settings Category] Category with specified id doesn't exist (" + id + ")!"); var cat = categories[id]; return { getId: function(){ return id; }, setVisibility: function(visible){ if (cat.visible === visible) return; cat.visible = visible; if (cat._visible) cat._visible(visible); }, setEnabled: function(enabled){ cat.enabled = enabled; }, addSubCategory: function(subcategory){ cat.subcategories.push(subcategories[subcategory.getId()]); }, select: function(){ if (cat.select) cat.select(); } }; }; a.getSubCategory = function(id){ if (subcategories.length <= id || id < 0) throw new Error("[Settings SubCategory] Category with specified id doesn't exist (" + id + ")!"); var subcat = subcategories[id]; return { getId: function(){ return id; }, setVisibility: function(visible){ if (subcat.visible === visible) return; subcat.visible = visible; if (subcat._visible) subcat._visible(visible); }, setEnabled: function(enabled){ subcat.enabled = enabled; }, addOption: function(option){ subcat.options.push(options[option.getId()]); }, select: function(){ if (subcat.select) subcat.select(); }, addEventListener: function(event, callback){ if (!subcat.listeners[event]) subcat.listeners[event] = []; subcat.listeners[event].push(callback); } }; }; a.getOption = function(id){ if (options.length <= id || id < 0) throw new Error("[Settings Options] Option with specified id doesn't exist (" + id + ")!"); var option = options[id]; return { getId: function(){ return id; }, getLabel: function(){ return option.label; }, getDefaultSetting: function(){ return option.defaultSetting; }, getModule: function(){ return option.module; }, getHelp: function(){ return option.help; }, setVisibility: function(visible){ if (option.visible === visible) return; option.visible = visible; if (option._visible) option._visible(visible); }, setEnabled: function(enabled){ option.enabled = enabled; }, setStyle: function(key, value){ option.styles[key] = value; }, getStyle: function(key){ return option.styles[key]; }, setModuleStyle: function(key, value){ option.moduleStyles[key] = value; }, getModuleStyle: function(key){ return option.moduleStyles[key]; }, addModuleEventListener: function(event, callback, bubble){ if (!option.moduleListeners) option.moduleListeners = []; option.moduleListeners.push([event, callback, bubble]); }, removeModuleEventListener: function(event, callback, bubble){ throw new Error("Not implemented!"); }, addEventListener: function(event, callback, bubble){ if (!option.listeners) option.listeners = {}; if (!option.listeners[event]) option.listeners[event] = []; option.listeners[event].push(callback); }, removeEventListener: function(event, callback, bubble){ if (!option.listeners) return; if (!option.listeners[event]) return; var i; for (i = 0; i < option.listeners[event].length; i++) { if (option.listeners[event][i] === callback) { option.listeners[event].splice(i, 1); return; } } }, getLiveModule: function(){ return option.liveModule; } }; }; a.createOptionsForLayout = function(subcat){ var frag = document.createDocumentFragment(); subcat.options.forEach(function(option){ var optionWrapper = document.createElement("div"), label, module, moduleContainer, labelText, help, replaceHelp, i; optionWrapper.className = "ytcenter-settings-subcat-option" + (option.visible ? "" : " hid"); option._visible = function(visible){ if (visible) { ytcenter.utils.removeClass(optionWrapper, "hid"); } else { ytcenter.utils.addClass(optionWrapper, "hid"); } }; if (option.label && option.label !== "") { labelText = document.createTextNode(ytcenter.language.getLocale(option.label)); ytcenter.language.addLocaleElement(labelText, option.label, "@textContent"); if (option.styles) { ytcenter.utils.each(option.styles, function(key, value){ optionWrapper.style.setProperty(key, value); }); } label = document.createElement("span"); label.className = "ytcenter-settings-option-label"; label.appendChild(labelText); if (option.help && option.help !== "") { help = document.createElement("a"); help.className = "ytcenter-settings-help"; help.setAttribute("target", "_blank"); help.setAttribute("href", option.help); help.appendChild(document.createTextNode('?')); replaceHelp = { "{option}": function() { return ytcenter.language.getLocale(option.label); } }; help.setAttribute("title", ytcenter.utils.replaceTextToText(ytcenter.language.getLocale("SETTINGS_HELP_ABOUT"), replaceHelp)); ytcenter.language.addLocaleElement(help, "SETTINGS_HELP_ABOUT", "title", replaceHelp); label.appendChild(help); } optionWrapper.appendChild(label); } if (option.defaultSetting && !(option.defaultSetting in ytcenter._settings)) { con.warn("[SettingsPanel] An option was registered, which doesn't have a default option (" + option.defaultSetting + ")."); } if (!option.module) { } else { if (!ytcenter.modules[option.module]) throw new Error("[Settings createOptionsForLayout] Option (" + option.id + ", " + option.label + ", " + option.module + ") are using an non existing module!"); moduleContainer = document.createElement("div"); moduleContainer.className = "ytcenter-module-container"; if (!option.label || option.label === "") { moduleContainer.style.width = "100%"; } if (option.moduleStyles) { ytcenter.utils.each(option.moduleStyles, function(key, value){ moduleContainer.style.setProperty(key, value); }); } option.parent = a.getSubCategory(subcat.id); module = ytcenter.modules[option.module](option); option.liveModule = module; moduleContainer.appendChild(module.element); module.bind(function(value){ if (typeof option.defaultSetting !== "undefined" && typeof ytcenter.settings[option.defaultSetting] !== "undefined") { ytcenter.settings[option.defaultSetting] = value; ytcenter.saveSettings(); } //ytcenter.events.performEvent("ui-refresh"); if (option.listeners && option.listeners["update"]) { for (i = 0; i < option.listeners["update"].length; i++) { option.listeners["update"][i](value); } } ytcenter.events.performEvent("settings-update", option.id); }); ytcenter.events.addEvent("settings-update", function(id){ if (module && id !== option.id && option.defaultSetting && ytcenter.settings[option.defaultSetting]) { module.update(ytcenter.settings[option.defaultSetting]); } }); if (module && option.defaultSetting && ytcenter.settings[option.defaultSetting]) { module.update(ytcenter.settings[option.defaultSetting]); } if (option.moduleListeners) { if (module.addEventListener) { for (i = 0; i < option.moduleListeners.length; i++) { module.addEventListener(option.moduleListeners[i][0], option.moduleListeners[i][1], option.moduleListeners[i][2]); } } else { throw new Error(option.module + " do not support listeners!"); } } optionWrapper.appendChild(moduleContainer); } frag.appendChild(optionWrapper); }); return frag; }; a.createLayout = function(){ var frag = document.createDocumentFragment(), categoryList = document.createElement("ul"), subcatList = [], sSelectedList = [], leftPanel = document.createElement("div"), rightPanel = document.createElement("div"), rightPanelContent = document.createElement("div"), productVersion = document.createElement("div"), subcatTop = document.createElement("div"), subcatContent = document.createElement("div"), panelWrapper = document.createElement("div"), categoryHide = false; subcatTop.className = "ytcenter-settings-subcat-header-wrapper"; subcatContent.className = "ytcenter-settings-subcat-content-wrapper"; leftPanel.className = "ytcenter-settings-panel-left clearfix"; rightPanel.className = "ytcenter-settings-panel-right clearfix"; productVersion.className = "ytcenter-settings-version"; if (devbuild) { ytcenter.events.addEvent("language-refresh", function(){ productVersion.innerHTML = ""; productVersion.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("DEV_BUILD"), { "{n}": document.createTextNode(devnumber) })); }); productVersion.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("DEV_BUILD"), { "{n}": document.createTextNode(devnumber) })); } else { productVersion.textContent = "YouTube Center v" + ytcenter.version; } categoryList.className = "ytcenter-settings-category-list"; categories.forEach(function(category){ var li = document.createElement("li"), acat = document.createElement("a"), valign = document.createElement("span"), text = document.createElement("span"), subcatLinkList = [], subcatContentList = [], topheader = document.createElement("div"), topheaderList = document.createElement("ul"), categoryContent = document.createElement("div"), hideContent = false; if (li && !category.visible) li.className = "hid"; sSelectedList.push(acat); acat.setAttribute("onclick", ";return false;"); acat.href = "#"; acat.className = "ytcenter-settings-category-item yt-valign" + (categoryHide || !category.visible ? "" : " ytcenter-selected"); ytcenter.utils.addEventListener(acat, "click", function(e){ category.select(); if (category.subcategories.length > 0 && category.subcategories[0] && category.subcategories[0].select) category.subcategories[0].select(); //ytcenter.events.performEvent("ui-refresh"); e.preventDefault(); e.stopPropagation(); return false; }, false); valign.className = "yt-valign-container"; text.textContent = ytcenter.language.getLocale(category.label); ytcenter.language.addLocaleElement(text, category.label, "@textContent"); valign.appendChild(text); acat.appendChild(valign); li.appendChild(acat); categoryList.appendChild(li); topheaderList.className = "ytcenter-settings-subcat-header clearfix"; category.subcategories.forEach(function(subcat){ var content = document.createElement("div"), liItem = document.createElement("li"), liItemLink = document.createElement("a"), itemTextContent = document.createElement("span"); content.className = "ytcenter-settings-subcat-content" + (hideContent ? " hid" : ""); liItem.className = "clearfix"; liItemLink.className = "yt-uix-button ytcenter-settings-subcat-header-item" + (hideContent ? "" : " ytcenter-selected"); itemTextContent.className = "ytcenter-settings-subcat-header-item-content"; itemTextContent.textContent = ytcenter.language.getLocale(subcat.label); ytcenter.language.addLocaleElement(itemTextContent, subcat.label, "@textContent"); content.appendChild(a.createOptionsForLayout(subcat)); liItemLink.appendChild(itemTextContent); liItem.appendChild(liItemLink); topheaderList.appendChild(liItem); ytcenter.utils.addEventListener(liItemLink, "click", function(e){ subcat.select(); //ytcenter.events.performEvent("ui-refresh"); e.preventDefault(); e.stopPropagation(); return false; }, false); subcatLinkList.push(liItemLink); subcatContentList.push(content); subcat.select = function(){ if (!subcat.visible) return; subcatLinkList.forEach(function(item){ ytcenter.utils.removeClass(item, "ytcenter-selected"); }); subcatContentList.forEach(function(item){ ytcenter.utils.addClass(item, "hid"); }); ytcenter.utils.removeClass(content, "hid"); ytcenter.utils.addClass(liItemLink, "ytcenter-selected"); if (subcat.listeners.click) { subcat.listeners.click.forEach(function(callback){ callback(); }); } }; subcat._visible = function(visible){ if (visible) { try { category.subcategories.forEach(function(subcat2){ if (subcat2.visible && subcat2 !== subcat) { throw "SelectedException"; } }); if (subcat.select) subcat.select(); } catch (e) { if (e !== "SelectedException") throw e; } ytcenter.utils.removeClass(liItem, "hid"); } else { ytcenter.utils.addClass(liItem, "hid"); ytcenter.utils.addClass(content, "hid"); if (ytcenter.utils.hasClass(liItemLink, "ytcenter-selected")) { try { category.subcategories.forEach(function(subcat2){ if (subcat2.visible && subcat2.select) { if (subcat2.select()) throw "SelectedException"; } }); } catch (e) { if (e !== "SelectedException") throw e; } } ytcenter.utils.removeClass(liItemLink, "ytcenter-selected"); } }; categoryContent.appendChild(content); hideContent = true; }); topheader.appendChild(topheaderList); topheader.className = (categoryHide || !category.visible ? "hid" : ""); categoryContent.className = (categoryHide || !category.visible ? "hid" : ""); subcatList.push(topheader); subcatList.push(categoryContent); subcatTop.appendChild(topheader); subcatContent.appendChild(categoryContent); category.select = function(){ if (!category.visible) return false; sSelectedList.forEach(function(item){ ytcenter.utils.removeClass(item, "ytcenter-selected"); }); subcatList.forEach(function(item){ ytcenter.utils.addClass(item, "hid"); }); ytcenter.utils.addClass(acat, "ytcenter-selected"); ytcenter.utils.removeClass(topheader, "hid"); ytcenter.utils.removeClass(categoryContent, "hid"); return true; }; category._visible = function(visible){ if (visible) { ytcenter.utils.removeClass(li, "hid"); } else { ytcenter.utils.addClass(li, "hid"); ytcenter.utils.addClass(topheader, "hid"); ytcenter.utils.addClass(categoryContent, "hid"); if (ytcenter.utils.hasClass(acat, "ytcenter-selected")) { try { categories.forEach(function(category2){ if (category2.visible && category2.select) { if (category2.select()) throw "SelectedException"; } }); } catch (e) { if (e !== "SelectedException") throw e; } } ytcenter.utils.removeClass(acat, "ytcenter-selected"); } }; if (category.visible) categoryHide = true; }); leftPanel.appendChild(categoryList); leftPanel.appendChild(productVersion); rightPanelContent.appendChild(subcatTop); rightPanelContent.appendChild(subcatContent); var statusbar = document.createElement("div"); statusbar.className = "ytcenter-settings-subcat-statusbar-wrapper"; statusbar.textContent = ""; (function(){ var savedTimeout = null, mode = 0; ytcenter.events.addEvent("language-refresh", function(){ if (mode === 0) { statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_SAVING"); } else if (mode === 1) { statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_SAVED"); } else if (mode === -1) { statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_ERROR"); } }); ytcenter.events.addEvent("save", function(){ if (savedTimeout) { uw.clearTimeout(savedTimeout); savedTimeout = null; } mode = 0; statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_SAVING"); ytcenter.utils.addClass(statusbar, "visible"); }); ytcenter.events.addEvent("save-complete", function(){ mode = 1; statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_SAVED"); if (savedTimeout) { uw.clearTimeout(savedTimeout); savedTimeout = null; } savedTimeout = uw.setTimeout(function(){ ytcenter.utils.removeClass(statusbar, "visible"); savedTimeout = null; }, ytcenter.settings.saveStatusTimeout); }); ytcenter.events.addEvent("save-error", function(){ mode = -1; statusbar.textContent = ytcenter.language.getLocale("STATUSBAR_SETTINGS_ERROR"); if (savedTimeout) { uw.clearTimeout(savedTimeout); savedTimeout = null; } savedTimeout = uw.setTimeout(function(){ ytcenter.utils.removeClass(statusbar, "visible"); savedTimeout = null; }, ytcenter.settings.saveErrorStatusTimeout); }); })(); rightPanelContent.appendChild(statusbar); rightPanel.appendChild(rightPanelContent); rightPanelContent.className = "ytcenter-settings-panel-right-content"; panelWrapper.className = "ytcenter-settings-content"; panelWrapper.appendChild(leftPanel); panelWrapper.appendChild(rightPanel); frag.appendChild(panelWrapper); return frag; }; a.createDialog = function(){ var dialog = ytcenter.dialog("SETTINGS_TITLE", a.createLayout(), [], "top"), closeButton = document.createElement("div"), closeIcon = document.createElement("img"); closeIcon.className = "close"; closeIcon.setAttribute("src", "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"); closeButton.className = "ytcenter-alert ytcenter-settings-close-button"; closeButton.appendChild(closeIcon); ytcenter.utils.addEventListener(closeButton, "click", function(){ dialog.setVisibility(false); }, false); dialog.getRoot().id = "ytcenter-settings"; dialog.getHeader().appendChild(closeButton); dialog.getHeader().style.margin = "0 -20px 0px"; dialog.getBase().style.overflowY = "scroll"; dialog.getFooter().style.display = "none"; dialog.getContent().className += " clearfix"; return dialog; }; return a; })(); var _settingsInit = false; function settingsInit(){ var cat, subcat, option; if (_settingsInit || !ytcenter.settingsPanel || !ytcenter.__settingsLoaded) return; _settingsInit = true; /* Category:General */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_TAB_GENERAL"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "language", // defaultSetting "list", // Module "SETTINGS_LANGUAGE", // label { // Args "list": function(){ function sortCompare(a, b) { if (a === "en-US") return -1; if (b === "en-US") return 1; if (ytcenter.languages[a].LANGUAGE < ytcenter.languages[b].LANGUAGE) return -1; if (ytcenter.languages[a].LANGUAGE > ytcenter.languages[b].LANGUAGE) return 1; return 0; } var sortList = []; for (var key in ytcenter.languages) { if (ytcenter.languages.hasOwnProperty(key)) { sortList.push(key); } } sortList.sort(sortCompare); var a = []; a.push({ "label": "LANGUAGE_AUTO", "value": "auto" }); for (var i = 0, len = sortList.length; i < len; i++) { a.push({ "value": sortList[i], "label": (function(key){ return function(){ return ytcenter.languages[key].LANGUAGE; }; })(sortList[i]) }); } return a; }, "listeners": [ { "event": "update", "callback": function(){ ytcenter.language.update(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Multiple_Languages" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "useSecureProtocol", // defaultSetting "bool", // module "SETTINGS_USESECUREPROTOCOL_LABEL", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Use_Secure_Protocol" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "removeAdvertisements", // defaultSetting "bool", // module "SETTINGS_REMOVEADVERTISEMENTS_LABEL", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_Advertisements" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "ytspf", // defaultSetting "bool", // module "SETTINGS_YTSPF", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-SPF" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "expandDescription", // defaultSetting "bool", // module "SETTINGS_AUTOEXPANDDESCRIPTION_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Expand_Description" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "headlineTitleExpanded", // defaultSetting "bool", // module "SETTINGS_AUTOEXPANDTITLE_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Expand_Title" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channelUploadedVideosPlaylist", // defaultSetting "bool", // module "SETTINGS_CHANNELUPLOADVIDEOSPLAYLIST_LABEL" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "removeYouTubeTitleSuffix", // defaultSetting "bool", // module "SETTINGS_TITLE_REMOVE_YOUTUBE_SUFFIX", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.title.update(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_YouTube_Title_Suffix" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerPlayingTitleIndicator", // defaultSetting "bool", // module "SETTINGS_PLAYER_PLAYING_INDICATOR", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.title.update(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_Player_Playing_Icon_In_Title" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerOnlyOneInstancePlaying", // defaultSetting "bool", // module "SETTINGS_PLAYER_ONLY_ONE_INSTANCE_PLAYING", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Only_One_Player_Instance_Playing" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "importexport" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "button", null, { "text": "SETTINGS_RESETSETTINGS_LABEL", "listeners": [ { "event": "click", "callback": function(){ var msgElm = document.createElement("h3"); msgElm.style.fontWeight = "normal"; msgElm.textContent = ytcenter.language.getLocale("SETTINGS_RESETSETTINGS_TEXT"); ytcenter.language.addLocaleElement(msgElm, "SETTINGS_RESETSETTINGS_TEXT", "@textContent"); var dialog = ytcenter.dialog("SETTINGS_RESETSETTINGS_LABEL", msgElm, [ { label: "CONFIRM_CANCEL", primary: false, callback: function(){ dialog.setVisibility(false); } }, { label: "CONFIRM_RESET", primary: true, callback: function(){ ytcenter.settings = ytcenter._settings; ytcenter.saveSettings(false); uw.setTimeout(function(){ loc.reload(); dialog.setVisibility(false); }, 500); } } ]); dialog.setVisibility(true); } } ] } ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_WATCHEDVIDEOS"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "watchedVideosIndicator", // defaultSetting "bool", // module "SETTINGS_WATCHEDVIDEOS_INDICATOR", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Watched_Videos" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "hideWatchedVideos", // defaultSetting "bool", // module "SETTINGS_HIDEWATCHEDVIDEOS", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["hide-watched-videos"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Watched_Videos" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "button", // module null, { "text": "SETTINGS_WATCHEDVIDEOS_CLEAN_VIDEO_HISTORY", "listeners": [ { "event": "click", "callback": function(){ var msgElm = document.createElement("h3"); msgElm.style.fontWeight = "normal"; msgElm.textContent = ytcenter.language.getLocale("SETTINGS_WATCHEDVIDEOS_CLEAN_VIDEO_HISTORY_CONTENT"); ytcenter.language.addLocaleElement(msgElm, "SETTINGS_WATCHEDVIDEOS_CLEAN_VIDEO_HISTORY_CONTENT", "@textContent"); var dialog = ytcenter.dialog("SETTINGS_WATCHEDVIDEOS_CLEAN_VIDEO_HISTORY", msgElm, [ { label: "CONFIRM_CANCEL", primary: false, callback: function(){ dialog.setVisibility(false); } }, { label: "CONFIRM_CLEAN", primary: true, callback: function(){ ytcenter.settings.watchedVideos = []; ytcenter.settings.notwatchedVideos = []; ytcenter.saveSettings(false, function(){ loc.reload(); dialog.setVisibility(false); }); } } ]); dialog.setVisibility(true); } } ] } ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_LAYOUT"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "flexWidthOnPage", // defaultSetting "bool", // module "SETTINGS_FLEXWIDTHONPAGE_LABEL", // label { // args "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["flex"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flex_Width_on_Page" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "flexWidthOnChannelPage", // defaultSetting "bool", // module "SETTINGS_FLEXWIDTHONCHANNELPAGE_LABEL", // label { // args "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["flex"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flex_Width_on_Channel" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "gridSubscriptionsPage", // defaultSetting "bool", // module "SETTINGS_GRIDSUBSCRIPTIONS", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Grid_Subscriptions" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["gridview"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "gridCollectionPage", // defaultSetting "bool", // module "SETTINGS_GRIDCOLLECTIONS", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Grid_Collections" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["gridview"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "hideTicker", // defaultSetting "bool", // module "SETTINGS_HIDE_TICKER", "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Ticker" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["hide-ticker"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "hideLangAlert", // defaultSetting "bool", // module "SETTINGS_HIDE_LANG_ALERT" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["hide-lang"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "staticHeader", // defaultSetting "bool", // module "SETTINGS_STATIC_HEADER" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["header"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "staticHeader_scrollToPlayer", // defaultSetting "bool", // module "SETTINGS_SCROLLTOPLAYER_LABEL" ); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ opt.setVisibility(ytcenter.settings.staticHeader); }; })(option)); option.setVisibility(ytcenter.settings.staticHeader); subcat.addOption(option); /*option = ytcenter.settingsPanel.createOption( "yonezCleanYT", // defaultSetting "bool", // module "SETTINGS_LAYOUT_YONEZ_CLEAN_YT" ); option.addEventListener("update", function(){ if (ytcenter.settings.yonezCleanYT) { ytcenter.cssElements.yonez.add(); } else { ytcenter.cssElements.yonez.remove(); } }); subcat.addOption(option);*/ /* Category:Player */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_PLAYER"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "removeRelatedVideosEndscreen", // defaultSetting "bool", // module "SETTINGS_REMOVE_RELATED_VIDEOS_ENDSCREEN", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_Endscreen" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "enableEndscreenAutoplay", // defaultSetting "bool", // module "SETTINGS_ENDSCREEN_AUTOPLAY", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Play_First_Video_in_Endscreen" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likeSwitchToTab", "list", "SETTINGS_SWITCHTOTAB_LIKE", { "list": [ { "value": "none", "label": "SETTINGS_SWITCHTOTAB_NONE" }, { "value": "share", "label": "SETTINGS_SWITCHTOTAB_SHARE" }/*, { "value": "stats", "label": "SETTINGS_SWITCHTOTAB_STATS" }, { "value": "report", "label": "SETTINGS_SWITCHTOTAB_REPORT" }, { "value": "ratings-disabled", "label": "SETTINGS_SWITCHTOTAB_RATINGS_DISABLED" }, { "value": "rental-required", "label": "SETTINGS_SWITCHTOTAB_RENTAL_REQUIRED" }, { "value": "error", "label": "SETTINGS_SWITCHTOTAB_ERROR" }*/ ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Switch_To_Tab_At_Like_of_Video" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "endOfVideoAutoSwitchToTab", "list", "SETTINGS_SWITCHTOTAB_ENDOFVIDEO", { "list": [ { "value": "none", "label": "SETTINGS_SWITCHTOTAB_NONE" }, { "value": "share", "label": "SETTINGS_SWITCHTOTAB_SHARE" }, { "value": "stats", "label": "SETTINGS_SWITCHTOTAB_STATS" }, { "value": "report", "label": "SETTINGS_SWITCHTOTAB_REPORT" }, { "value": "ratings-disabled", "label": "SETTINGS_SWITCHTOTAB_RATINGS_DISABLED" }, { "value": "rental-required", "label": "SETTINGS_SWITCHTOTAB_RENTAL_REQUIRED" }, { "value": "error", "label": "SETTINGS_SWITCHTOTAB_ERROR" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Switch_To_Tab_At_End_of_Video" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dashPlayback", // defaultSetting "bool", // module "SETTINGS_DASHPLAYBACK", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-DASH_Playback" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "forcePlayerType", // defaultSetting "list", // module "SETTINGS_FORCEPLAYERTYPE", { "list": [ { "value": "default", "label": "SETTINGS_FORCEPLAYERTYPE_DEFAULT" }, { "value": "flash", "label": "SETTINGS_FORCEPLAYERTYPE_FLASH" }, { "value": "html5", "label": "SETTINGS_FORCEPLAYERTYPE_HTML5" }, { "value": "aggressive_flash", "label": "SETTINGS_FORCEPLAYERTYPE_AGGRESSIVE_FLASH" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Type" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "autohide", // defaultSetting "list", // module "SETTINGS_AUTOHIDECONTROLBAR_LABEL", { "list": [ { "value": "-1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_DEFAULT" }, { "value": "0", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_NONE" }, { "value": "1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_BOTH" }, { "value": "2", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_PROGRESSBAR" }, { "value": "3", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_CONTROLBAR" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.page === "watch") { ytcenter.player.setAutoHide(ytcenter.settings.autohide); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Hide_Bar" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerTheme", // defaultSetting "list", // module "SETTINGS_PLAYERTHEME_LABEL", { "list": [ { "value": "dark", "label": "SETTINGS_PLAYERTHEME_DARK" }, { "value": "light", "label": "SETTINGS_PLAYERTHEME_LIGHT" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.page === "watch") { ytcenter.player.setTheme(ytcenter.settings.playerTheme); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Theme" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerColor", // defaultSetting "list", // module "SETTINGS_PLAYERCOLOR_LABEL", { "list": [ { "value": "red", "label": "SETTINGS_PLAYERCOLOR_RED" }, { "value": "white", "label": "SETTINGS_PLAYERCOLOR_WHITE" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.page === "watch") { ytcenter.player.setProgressColor(ytcenter.settings.playerColor); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Color" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "flashWMode", // defaultSetting "list", // module "SETTINGS_WMODE_LABEL", { "list": [ { "value": "none", "label": "SETTINGS_WMODE_NONE" }, { "value": "window", "label": "SETTINGS_WMODE_WINDOW" }, { "value": "direct", "label": "SETTINGS_WMODE_DIRECT" }, { "value": "opaque", "label": "SETTINGS_WMODE_OPAQUE" }, { "value": "transparent", "label": "SETTINGS_WMODE_TRANSPARENT" }, { "value": "gpu", "label": "SETTINGS_WMODE_GPU" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flash_WMode" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "enableAnnotations", // defaultSetting "bool", // module "SETTINGS_ENABLEANNOTATIONS_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Annotations" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "bufferEnabled", // defaultSetting "bool", // module "SETTINGS_BUFFER_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Enable_custom_buffer" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "bufferSize", // defaultSetting "rangetext", // module "SETTINGS_BUFFER_SIZE", { "min": 0, /* 0 bytes - I have no idea if this will break something */ "max": 1099511627776, /* 1 TB - Why not... */ "suffix": " B", "text-width": "135px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Custom_buffer_size" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "line" ); subcat.addOption(option); /*option = ytcenter.settingsPanel.createOption( "removeBrandingBanner", // defaultSetting "bool", // module "SETTINGS_BRANDING_BANNER_REMOVE", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_Branding_Banner" ); subcat.addOption(option);*/ /*option = ytcenter.settingsPanel.createOption( "removeBrandingBackground", // defaultSetting "bool", // module "SETTINGS_BRANDING_BACKGROUND_REMOVE", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_Branding_Background" ); subcat.addOption(option);*/ option = ytcenter.settingsPanel.createOption( "removeBrandingWatermark", // defaultSetting "bool", // module "SETTINGS_BRANDING_WATERMARK_REMOVE", // label { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_Branding_Watermark" ); subcat.addOption(option); if (devbuild) { option = ytcenter.settingsPanel.createOption( null, // defaultSetting "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "enable_custom_fexp", // defaultSetting "bool", // module "SETTINGS_ENABLE_CUSTOM_FEXP" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "custom_fexp", // defaultSetting "textfield", // module "SETTINGS_CUSTOM_FEXP" ); subcat.addOption(option); } subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_AUTOPLAY"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "preventAutoPlay", // defaultSetting "bool", // module "SETTINGS_PREVENTAUTOPLAY_LABEL", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoPlay" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventAutoBuffer", // defaultSetting "bool", // module "SETTINGS_PREVENTAUTOBUFFERING_LABEL", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoBuffering" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "newline" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventPlaylistAutoPlay", // defaultSetting "bool", // module "SETTINGS_PLAYLIST_PREVENT_AUTOPLAY", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Playlist_AutoPlay" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventPlaylistAutoBuffer", // defaultSetting "bool", // module "SETTINGS_PLAYLIST_PREVENT_AUTOBUFFERING", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Playlist_AutoBuffering" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "newline" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventTabAutoPlay", // defaultSetting "bool", // module "SETTINGS_PREVENTTABAUTOPLAY_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Tab_AutoPlay" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventTabAutoBuffer", // defaultSetting "bool", // module "SETTINGS_PREVENTTABAUTOBUFFERING_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Tab_AutoBuffering" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "newline" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventTabPlaylistAutoPlay", // defaultSetting "bool", // module "SETTINGS_PREVENTTABPLAYLISTAUTOPLAY_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Tab_Playlist_AutoPlay" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "preventTabPlaylistAutoBuffer", // defaultSetting "bool", // module "SETTINGS_PREVENTTABPLAYLISTAUTOBUFFERING_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_Tab_Playlist_AutoBuffering" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "newline" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playlistAutoPlay", // defaultSetting "bool", // module "SETTINGS_PLAYLIST_AUTOPLAY", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Playlist_auto_play" ); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ var module = opt.getLiveModule(); if (module) { module.update(ytcenter.settings.playlistAutoPlay); } }; })(option)); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playlistAutoPlayFreeze", // defaultSetting "bool", // module "SETTINGS_PLAYLIST_AUTOPLAY_FREEZE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Playlist_auto_play_freeze" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_RESOLUTION"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableAutoVideoQuality", // defaultSetting "bool", // module "SETTINGS_ENABLEAUTORESOLUTION_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Auto_Resolution" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "autoVideoQuality", // defaultSetting "list", // module "SETTINGS_AUTORESOLUTION_LABEL", { "list": [ { "value": "highres", "label": "SETTINGS_HIGHRES" }, { "value": "hd1440", "label": "SETTINGS_HD1440" }, { "value": "hd1080", "label": "SETTINGS_HD1080" }, { "value": "hd720", "label": "SETTINGS_HD720" }, { "value": "large", "label": "SETTINGS_LARGE" }, { "value": "medium", "label": "SETTINGS_MEDIUM" }, { "value": "small", "label": "SETTINGS_SMALL" }, { "value": "tiny", "label": "SETTINGS_TINY" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Resolution" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_PLAYERSIZE"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableResize", // defaultSetting "bool", // module "SETTINGS_RESIZE_FEATURE_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Size" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "resize-default-playersize", // defaultSetting "defaultplayersizedropdown", // module "SETTINGS_RESIZE_DEFAULT", { "bind": "resize-playersizes" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Default_Player_Size" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "resize-small-button", // defaultSetting "defaultplayersizedropdown", // module "SETTINGS_RESIZE_SMALL_BUTTON", { "bind": "resize-playersizes" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Small_Resize_Button" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "resize-large-button", // defaultSetting "defaultplayersizedropdown", // module "SETTINGS_RESIZE_LARGE_BUTTON", { "bind": "resize-playersizes" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Large_Resize_Button" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerSizeAspect", // defaultSetting "list", // module "SETTINGS_RESIZE_ASPECT_LABEL", { "list": [ { "value": "default", "label": "SETTINGS_RESIZE_ASPECT_DEFAULT" }, { "value": "4:3", // 1.33333 "label": "SETTINGS_RESIZE_ASPECT_4:3" }, { "value": "3:2", // 1.33333 "label": "SETTINGS_RESIZE_ASPECT_3:2" }, { "value": "5:4", // 1.25 "label": "SETTINGS_RESIZE_ASPECT_5:4" }, { "value": "16:9", // 1.7778 "label": "SETTINGS_RESIZE_ASPECT_16:9" }, { "value": "16:10", // 1.6 "label": "SETTINGS_RESIZE_ASPECT_16:10" }, { "value": "24:10", // 2.4 "label": "SETTINGS_RESIZE_ASPECT_24:10" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.player.setRatio(ytcenter.player.calculateRatio(ytcenter.player.getConfig().args.dash === "1" && ytcenter.player.getConfig().args.adaptive_fmts)); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Aspect" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "ytOnlyStageMode", // defaultSetting "bool", // module "SETTINGS_RESIZE_ONLY_STAGE_MODE", { "listeners" : [ { "event": "click", "callback": function(){ ytcenter.player.resizeUpdater(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Only_stage_mode" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting null, // module "SETTINGS_RESIZE_LIST", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Size_Editor" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "resize-playersizes", // defaultSetting "resizeItemList" // module ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_VOLUME"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableVolume", // defaultSetting "bool", // module "SETTINGS_VOLUME_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Volume_Control" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "volume", // defaultSetting "rangetext", // module "SETTINGS_VOLUME_LABEL", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Volume-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "mute", // defaultSetting "bool", // module "SETTINGS_MUTE_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Mute" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_SHORTCUTS"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableYouTubeShortcuts", // defaultSetting "bool", // module "SETTINGS_ENABLEYTSHORTCUTS_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_YouTube_Player_Shortcuts" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "enableShortcuts", // defaultSetting "bool", // module "SETTINGS_ENABLESHORTCUTS_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Shortcuts_on_Page" ); subcat.addOption(option); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ opt.setVisibility(ytcenter.settings.enableYouTubeShortcuts); }; })(option)); option.setVisibility(ytcenter.settings.enableYouTubeShortcuts); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_TOPSCROLLPLAYER"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "topScrollPlayerEnabled", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_ENABLED", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Fullscreen_Top_Player" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerActivated", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_ACTIVATED", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Activated_by_Default" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerEnabledOnlyVideoPlaying", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_ONLYVIDEOPLAYING", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Only_when_Video_is_Playing" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerEnterOnVideoPlay", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_ENTERONVIDEOPLAY", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enter_On_Video_Play" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerExitOnVideoPause", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_EXITONVIDEOPAUSE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Exit_On_Video_Pause" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerExitOnVideoEnd", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_EXITONVIDEOEND", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Exit_On_Video_End" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerScrollUpToExit", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_SCROLLUPEXIT", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Scroll_Up_To_Exit_Mode" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerAnimation", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_ANIMATION", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Animations" ); subcat.addOption(option); /*option = ytcenter.settingsPanel.createOption( "topScrollPlayerHideScrollbar", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_HIDESCROLLBAR", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#hide-scrollbar" ); subcat.addOption(option);*/ option = ytcenter.settingsPanel.createOption( "topScrollPlayerCountIncreaseBefore", // defaultSetting "bool", // module "SETTINGS_TOPSCROLLPLAYER_COUNTINCREASEBEFORE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Increase_Counter_by_Scrolling_To_The_Top_of_The_Page" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerTimesToEnter", // defaultSetting "rangetext", // module "SETTINGS_TOPSCROLLPLAYER_TIMESTOENTER", // label { "min": 0, "max": 20 }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Amount_To_Enter" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerTimesToExit", // defaultSetting "rangetext", // module "SETTINGS_TOPSCROLLPLAYER_TIMESTOEXIT", // label { "min": 0, "max": 20 }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Amount_To_Exit" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "topScrollPlayerBumpTimer", // defaultSetting "rangetext", // module "SETTINGS_TOPSCROLLPLAYER_BUMPTIMER", // label { "min": 0, "max": 10000, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Counter_Reset_After" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_PLAYERGLOW"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "playerGlowEnabled", // defaultSetting "bool", // module "SETTINGS_PLAYERGLOW_ENABLED", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Enabled" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setEnabled(ytcenter.settings.playerGlowEnabled); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowFactor", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_FACTOR", // label { "min": 1, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Quality" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("factor", ytcenter.settings.playerGlowFactor); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowPixelInterval", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_PIXEL_INTERVAL", // label { "min": 1, "max": 10000000 }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Pixel_interval" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("pixelInterval", ytcenter.settings.playerGlowPixelInterval); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowRequestAnimationFrame", // defaultSetting "bool", // module "SETTINGS_PLAYERGLOW_USE_REQUEST_ANIMATION_FRAME", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Use_request_animation_frame" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowUpdateInterval", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_UPDATE_INTERVAL", // label { "min": 0, "max": 10000, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Update_interval" ); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ ytcenter.effects.playerGlow.setOption("interval", (ytcenter.settings.playerGlowRequestAnimationFrame ? -1 : ytcenter.settings.playerGlowUpdateInterval)); opt.setVisibility(!ytcenter.settings.playerGlowRequestAnimationFrame); }; })(option)); option.setVisibility(!ytcenter.settings.playerGlowRequestAnimationFrame); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowTransition", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_TRANSITION", // label { "min": 0, "max": 10000, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Transition" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("transition", ytcenter.settings.playerGlowTransition); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowBlur", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_BLUR", // label { "min": 0, "max": 200, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Blur" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("blur", ytcenter.settings.playerGlowBlur); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowSpread", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_SPREAD", // label { "min": 0, "max": 200, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Spread" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("spread", ytcenter.settings.playerGlowSpread); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowOpacity", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_OPACITY", // label { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Opacity" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("opacity", ytcenter.settings.playerGlowOpacity/100); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerMultiGlowEffect", // defaultSetting "bool", // module "SETTINGS_PLAYERGLOW_MULTI_ENABLED", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Multi_glow_enabled" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("multiglow", ytcenter.settings.playerMultiGlowEffect); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerMultiGlowEffectDepth", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_MULTI_DEPTH", // label { "min": 1, "max": 500, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Depth" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("depth", ytcenter.settings.playerMultiGlowEffectDepth); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerMultiGlowEffectBlockInterval", // defaultSetting "rangetext", // module "SETTINGS_PLAYERGLOW_MULTI_BLOCK_INTERVAL", // label { "min": 1, "max": 200, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Block_interval" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("blockInterval", ytcenter.settings.playerMultiGlowEffectBlockInterval); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerGlowEffectOnPlayer", "list", "SETTINGS_PLAYERGLOW_APPLIED", { "list": [ { "value": "both", "label": "SETTINGS_PLAYERGLOW_LIGHTS_OFF_BOTH" }, { "value": "only-lights-off", "label": "SETTINGS_PLAYERGLOW_LIGHTS_OFF_ONLY_LIGHTS_OFF" }, { "value": "only-without-lights-off", "label": "SETTINGS_PLAYERGLOW_LIGHTS_OFF_ONLY_WITHOUT_LIGHTS_OFF" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Glow_on" ); ytcenter.events.addEvent("settings-update", function(){ ytcenter.effects.playerGlow.setOption("glowEffectOnPlayer", ytcenter.settings.playerGlowEffectOnPlayer); }); subcat.addOption(option); /* Category:External Players */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_EXTERNAL_PLAYERS"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_EMBED"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "embed_enabled", "bool", "SETTINGS_EMBEDS_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Embeds" ); subcat.addOption(option); // Only needed in the developer version for testing. if (devbuild) { option = ytcenter.settingsPanel.createOption( "embedWriteEmbedMethod", "list", "SETTINGS_EMBEDS_WRITEMETHOD", { "list": [ { "value": "standard", "label": "SETTINGS_EMBEDS_WRITEMETHOD_STANDARD" }, { "value": "test1", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST1" }, { "value": "test2", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST2" }, { "value": "test3", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST3" }, { "value": "standard+reload", "label": "SETTINGS_EMBEDS_WRITEMETHOD_STANDARDRELOAD" }, { "value": "test1+reload", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST1RELOAD" }, { "value": "test2+reload", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST2RELOAD" }, { "value": "test3+reload", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST3RELOAD" }, { "value": "test4", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST4" }, { "value": "test5", "label": "SETTINGS_EMBEDS_WRITEMETHOD_TEST5" } ] } ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embedWriteEmbedMethodReloadDelay", "rangetext", "SETTINGS_EMBEDS_WRITEMETHOD_RELOADDELAY", { "min": 0, "max": 10000, "suffix": " ms" } ); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ opt.setVisibility(ytcenter.settings.embedWriteEmbedMethod.indexOf("+reload") !== -1); }; })(option)); option.setVisibility(ytcenter.settings.embedWriteEmbedMethod.indexOf("+reload") !== -1); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); } option = ytcenter.settingsPanel.createOption( "embed_dashPlayback", "bool", "SETTINGS_DASHPLAYBACK", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-DASH_Playback-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_forcePlayerType", "list", "SETTINGS_FORCEPLAYERTYPE", { "list": [ { "value": "default", "label": "SETTINGS_FORCEPLAYERTYPE_DEFAULT" }, { "value": "flash", "label": "SETTINGS_FORCEPLAYERTYPE_FLASH" }, { "value": "html5", "label": "SETTINGS_FORCEPLAYERTYPE_HTML5" }, { "value": "aggressive_flash", "label": "SETTINGS_FORCEPLAYERTYPE_AGGRESSIVE_FLASH" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Type-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_autohide", "list", "SETTINGS_AUTOHIDECONTROLBAR_LABEL", { "list": [ { "value": "-1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_DEFAULT" }, { "value": "0", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_NONE" }, { "value": "1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_BOTH" }, { "value": "2", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_PROGRESSBAR" }, { "value": "3", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_CONTROLBAR" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setAutoHide(ytcenter.settings.embed_autohide); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Hide_Bar-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_playerTheme", "list", "SETTINGS_PLAYERTHEME_LABEL", { "list": [ { "value": "dark", "label": "SETTINGS_PLAYERTHEME_DARK" }, { "value": "light", "label": "SETTINGS_PLAYERTHEME_LIGHT" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setTheme(ytcenter.settings.embed_playerTheme); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Theme-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_playerColor", "list", "SETTINGS_PLAYERCOLOR_LABEL", { "list": [ { "value": "red", "label": "SETTINGS_PLAYERCOLOR_RED" }, { "value": "white", "label": "SETTINGS_PLAYERCOLOR_WHITE" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setProgressColor(ytcenter.settings.embed_playerColor); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Color-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_flashWMode", "list", "SETTINGS_WMODE_LABEL", { "list": [ { "value": "none", "label": "SETTINGS_WMODE_NONE" }, { "value": "window", "label": "SETTINGS_WMODE_WINDOW" }, { "value": "direct", "label": "SETTINGS_WMODE_DIRECT" }, { "value": "opaque", "label": "SETTINGS_WMODE_OPAQUE" }, { "value": "transparent", "label": "SETTINGS_WMODE_TRANSPARENT" }, { "value": "gpu", "label": "SETTINGS_WMODE_GPU" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flash_WMode-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_enableAnnotations", "bool", "SETTINGS_ENABLEANNOTATIONS_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Annotations-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embedBufferEnabled", // defaultSetting "bool", // module "SETTINGS_BUFFER_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Enable_custom_buffer" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embedBufferSize", // defaultSetting "rangetext", // module "SETTINGS_BUFFER_SIZE", { "min": 0, /* 0 bytes - I have no idea if this will break something */ "max": 1099511627776, /* 1 TB - Why not... */ "suffix": " B", "text-width": "135px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Custom_buffer_size" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_enableAutoVideoQuality", "bool", "SETTINGS_ENABLEAUTORESOLUTION_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Auto_Resolution-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_autoVideoQuality", "list", "SETTINGS_AUTORESOLUTION_LABEL", { "list": [ { "value": "highres", "label": "SETTINGS_HIGHRES" }, { "value": "hd1440", "label": "SETTINGS_HD1440" }, { "value": "hd1080", "label": "SETTINGS_HD1080" }, { "value": "hd720", "label": "SETTINGS_HD720" }, { "value": "large", "label": "SETTINGS_LARGE" }, { "value": "medium", "label": "SETTINGS_MEDIUM" }, { "value": "small", "label": "SETTINGS_SMALL" }, { "value": "tiny", "label": "SETTINGS_TINY" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Resolution-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_defaultAutoplay", "bool", "SETTINGS_DEFAULT_AUTOPLAY", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Use_Default_AutoPlay" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_preventAutoPlay", "bool", "SETTINGS_PREVENTAUTOPLAY_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoPlay-2" ); option.setVisibility(!ytcenter.settings.embed_defaultAutoplay); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ opt.setVisibility(!ytcenter.settings.embed_defaultAutoplay); }; })(option)); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_preventAutoBuffer", "bool", "SETTINGS_PREVENTAUTOBUFFERING_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoBuffering-2" ); option.setVisibility(!ytcenter.settings.embed_defaultAutoplay); ytcenter.events.addEvent("settings-update", (function(opt){ return function(){ opt.setVisibility(!ytcenter.settings.embed_defaultAutoplay); }; })(option)); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_enableVolume", "bool", "SETTINGS_VOLUME_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Volume_Control-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_volume", "rangetext", "SETTINGS_VOLUME_LABEL", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Volume-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "embed_mute", "bool", "SETTINGS_MUTE_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Mute-2" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_CHANNEL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "embed_dashPlayback", "bool", "SETTINGS_DASHPLAYBACK", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-DASH_Playback-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_forcePlayerType", "list", "SETTINGS_FORCEPLAYERTYPE", { "list": [ { "value": "default", "label": "SETTINGS_FORCEPLAYERTYPE_DEFAULT" }, { "value": "flash", "label": "SETTINGS_FORCEPLAYERTYPE_FLASH" }, { "value": "html5", "label": "SETTINGS_FORCEPLAYERTYPE_HTML5" }, { "value": "aggressive_flash", "label": "SETTINGS_FORCEPLAYERTYPE_AGGRESSIVE_FLASH" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Type-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_autohide", "list", "SETTINGS_AUTOHIDECONTROLBAR_LABEL", { "list": [ { "value": "-1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_DEFAULT" }, { "value": "0", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_NONE" }, { "value": "1", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_BOTH" }, { "value": "2", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_PROGRESSBAR" }, { "value": "3", "label": "SETTINGS_AUTOHIDECONTROLBAR_LIST_CONTROLBAR" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setAutoHide(ytcenter.settings.channel_autohide); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Hide_Bar-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_playerTheme", "list", "SETTINGS_PLAYERTHEME_LABEL", { "list": [ { "value": "dark", "label": "SETTINGS_PLAYERTHEME_DARK" }, { "value": "light", "label": "SETTINGS_PLAYERTHEME_LIGHT" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setTheme(ytcenter.settings.channel_playerTheme); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Theme-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_playerColor", "list", "SETTINGS_PLAYERCOLOR_LABEL", { "list": [ { "value": "red", "label": "SETTINGS_PLAYERCOLOR_RED" }, { "value": "white", "label": "SETTINGS_PLAYERCOLOR_WHITE" } ], "listeners" : [ { "event": "update", "callback": function(){ if (ytcenter.getPage() === "embed") { ytcenter.player.setProgressColor(ytcenter.settings.channel_playerColor); } } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Player_Color-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_flashWMode", "list", "SETTINGS_WMODE_LABEL", { "list": [ { "value": "none", "label": "SETTINGS_WMODE_NONE" }, { "value": "window", "label": "SETTINGS_WMODE_WINDOW" }, { "value": "direct", "label": "SETTINGS_WMODE_DIRECT" }, { "value": "opaque", "label": "SETTINGS_WMODE_OPAQUE" }, { "value": "transparent", "label": "SETTINGS_WMODE_TRANSPARENT" }, { "value": "gpu", "label": "SETTINGS_WMODE_GPU" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flash_WMode-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_enableAnnotations", "bool", "SETTINGS_ENABLEANNOTATIONS_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Annotations-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channelBufferEnabled", // defaultSetting "bool", // module "SETTINGS_BUFFER_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Enable_custom_buffer" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channelBufferSize", // defaultSetting "rangetext", // module "SETTINGS_BUFFER_SIZE", { "min": 0, /* 0 bytes - I have no idea if this will break something */ "max": 1099511627776, /* 1 TB - Why not... */ "suffix": " B", "text-width": "135px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Custom_buffer_size" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_enableAutoVideoQuality", "bool", "SETTINGS_ENABLEAUTORESOLUTION_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Auto_Resolution-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_autoVideoQuality", "list", "SETTINGS_AUTORESOLUTION_LABEL", { "list": [ { "value": "highres", "label": "SETTINGS_HIGHRES" }, { "value": "hd1440", "label": "SETTINGS_HD1440" }, { "value": "hd1080", "label": "SETTINGS_HD1080" }, { "value": "hd720", "label": "SETTINGS_HD720" }, { "value": "large", "label": "SETTINGS_LARGE" }, { "value": "medium", "label": "SETTINGS_MEDIUM" }, { "value": "small", "label": "SETTINGS_SMALL" }, { "value": "tiny", "label": "SETTINGS_TINY" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Resolution-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_preventAutoPlay", "bool", "SETTINGS_PREVENTAUTOPLAY_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoPlay-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_preventAutoBuffer", "bool", "SETTINGS_PREVENTAUTOBUFFERING_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Prevent_AutoBuffering-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_enableVolume", "bool", "SETTINGS_VOLUME_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Volume_Control-3" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_volume", "rangetext", "SETTINGS_VOLUME_LABEL", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Volume-4" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "channel_mute", "bool", "SETTINGS_MUTE_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Mute-3" ); subcat.addOption(option); /* Category:Download */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_DOWNLOAD"); if (identifier === 8) cat.setVisibility(false); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "downloadQuality", "list", "SETTINGS_DOWNLOADQUALITY_LABEL", { "list": [ { "value": "highres", "label": "SETTINGS_HIGHRES" }, { "value": "hd1440", "label": "SETTINGS_HD1440" }, { "value": "hd1080", "label": "SETTINGS_HD1080" }, { "value": "hd720", "label": "SETTINGS_HD720" }, { "value": "large", "label": "SETTINGS_LARGE" }, { "value": "medium", "label": "SETTINGS_MEDIUM" }, { "value": "small", "label": "SETTINGS_SMALL" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Quality" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "downloadFormat", "list", "SETTINGS_DOWNLOADFORMAT_LABEL", { "list": [ { "value": "mp4", "label": "SETTINGS_DOWNLOADFORMAT_LIST_MP4" }, { "value": "webm", "label": "SETTINGS_DOWNLOADFORMAT_LIST_WEBM" }, { "value": "flv", "label": "SETTINGS_DOWNLOADFORMAT_LIST_FLV" }, { "value": "3gp", "label": "SETTINGS_DOWNLOADFORMAT_LIST_3GP" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Format" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "downloadAsLinks", "bool", "SETTINGS_DOWNLOADASLINKS_LABEL", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Download_as_links" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "show3DInDownloadMenu", "bool", "SETTINGS_SHOW3DINDOWNLOADMENU_LABEL", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_3D_in_Download_Menu" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "filename", "textfield", "SETTINGS_FILENAME_LABEL", { "listeners": [ { "event": "change", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Filename" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "fixfilename", "bool", "SETTINGS_FIXDOWNLOADFILENAME_LABEL", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Remove_NonAlphanumeric_Characters" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_MP3SERVICES"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "mp3Services", "multilist", "SETTINGS_MP3SERVICES_LABEL", { "list": ytcenter.mp3services, "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-MP3_Services" ); option.setModuleStyle("display", "block"); subcat.addOption(option); /* Category:Repeat */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_REPEAT"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "autoActivateRepeat", "bool", "SETTINGS_AUTOACTIVATEREPEAT_LABEL", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Auto_Activate_Repeat" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "repeatShowIcon", "bool", "SETTINGS_REPEAT_SHOW_ICON", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_Icon" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "repeatShowText", "bool", "SETTINGS_REPEAT_SHOW_TEXT", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_Text" ); subcat.addOption(option); /* Category:UI */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_UI"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "guideMode", "list", "SETTINGS_GUIDEMODE", { "list": [ { "value": "default", "label": "SETTINGS_GUIDEMODE_DEFAULT" }, { "value": "always_open", "label": "SETTINGS_GUIDEMODE_ALWAYS_OPEN" }, { "value": "always_closed", "label": "SETTINGS_GUIDEMODE_ALWAYS_CLOSED" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Guide_Mode" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "watch7playerguidealwayshide", "bool", "SETTINGS_GUIDE_ALWAYS_HIDE", { "listeners": [ { "event": "click", "callback": function(){ /*ytcenter.guide.hidden = ytcenter.settings.watch7playerguidealwayshide; ytcenter.guide.update();*/ ytcenter.player._updateResize(); ytcenter.classManagement.updateClassesByGroup(["hide-guide"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Always_Hide_The_Guide" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "watch7playerguidehide", "bool", "SETTINGS_WATCH7_PLAYER_GUIDE_HIDE", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.player._updateResize(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Guide_When_Resizing" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "disableGuideCount", "bool", "SETTINGS_HIDE_GUIDE_COUNT", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["hide-guide-count"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Guide_Count" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line", null ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "logoLink", "textfield", "SETTINGS_LOGO_LINK", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.updateLogoLink(); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-YouTube_Logo_Link" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "disableFeedItemActionMenu", "bool", "SETTINGS_HIDE_FEED_ITEM_ACTION_MENU", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["hide-feed-item-action-menu"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Feed_Item_Action_Menu_Button" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "hideRecommendedChannels", "bool", "SETTINGS_HIDE_RECOMMENDED_CHANNELS", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["hide-recommended-channels"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Hide_Recommended_Channels" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line", null ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerDarkSideBG", "bool", "SETTINGS_PLAYER_DARK_SIDE", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["darkside"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Dark_Player_Background" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerDarkSideBGRetro", "bool", "SETTINGS_PLAYER_DARK_SIDE_RETRO", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Dark_player_background_retro" ); var playerDarkSideBGRetroOption = option; subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "playerDarkSideBGColor", "colorpicker", "SETTINGS_PLAYER_DARK_SIDE_COLOR", { "presetColors": ["#1b1b1b", "#444444"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["darkside"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Dark_Player_Background_Color" ); var playerDarkSideBGColorOption = option; playerDarkSideBGRetroOption.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["darkside"]); playerDarkSideBGColorOption.setVisibility(!ytcenter.settings.playerDarkSideBGRetro); }); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["darkside"]); }); if (ytcenter.settings.playerDarkSideBGRetro) option.setVisibility(false); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "line", null ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "uploaderCountryEnabled", // defaultSetting "bool", // module "SETTINGS_UPLOADER_COUNTRY_FLAG_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Country_Flag_for_Uploader" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "uploaderCountryShowFlag", // defaultSetting "bool", // module "SETTINGS_UPLOADER_COUNTRY_FLAG_SHOW_FLAG", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_Country_Flag" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "uploaderCountryUseNames", // defaultSetting "bool", // module "SETTINGS_UPLOADER_COUNTRY_FLAG_USE_NAME", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Use_Country_Names" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "uploaderCountryPosition", // defaultSetting "list", // module "SETTINGS_UPLOADER_COUNTRY_FLAG_POSITION", // label { "list": [ { "value": "before_username", "label": "SETTINGS_UPLOADER_COUNTRY_FLAG_POSITION_BEFORE_USERNAME" }, { "value": "after_username", "label": "SETTINGS_UPLOADER_COUNTRY_FLAG_POSITION_AFTER_USERNAME" }, { "value": "last", "label": "SETTINGS_UPLOADER_COUNTRY_FLAG_POSITION_LAST" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Flag_Country_Position" ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_LIKEDISLIKEBUTTON"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "likeButtonColor", "colorpicker", "SETTINGS_LIKEBUTTON_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttoncolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Like_button_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttoncolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likeButtonHoverColor", "colorpicker", "SETTINGS_LIKEBUTTON_HOVER_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttonhovercolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Like_button_hover_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttonhovercolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likeButtonOpacity", "rangetext", "SETTINGS_LIKEBUTTON_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Like_button_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likeButtonHoverOpacity", "rangetext", "SETTINGS_LIKEBUTTON_HOVER_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Like_button_hover_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likebuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikeButtonColor", "colorpicker", "SETTINGS_DISLIKEBUTTON_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttoncolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Dislike_button_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttoncolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikeButtonHoverColor", "colorpicker", "SETTINGS_DISLIKEBUTTON_HOVER_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttonhovercolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Dislike_button_hover_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttonhovercolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikeButtonOpacity", "rangetext", "SETTINGS_DISLIKEBUTTON_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Dislike_button_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikeButtonHoverOpacity", "rangetext", "SETTINGS_DISLIKEBUTTON_HOVER_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Dislike_button_hover_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikebuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likedButtonColor", "colorpicker", "SETTINGS_LIKEDBUTTON_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttoncolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Liked_button_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttoncolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likedButtonHoverColor", "colorpicker", "SETTINGS_LIKEDBUTTON_HOVER_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttonhovercolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Liked_button_hover_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttonhovercolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likedButtonOpacity", "rangetext", "SETTINGS_LIKEDBUTTON_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Liked_button_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "likedButtonHoverOpacity", "rangetext", "SETTINGS_LIKEDBUTTON_HOVER_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Liked_button_hover_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["likedbuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikedButtonColor", "colorpicker", "SETTINGS_DISLIKEDBUTTON_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttoncolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Disliked_button_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttoncolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikedButtonHoverColor", "colorpicker", "SETTINGS_DISLIKEDBUTTON_HOVER_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff", "#000"], "listeners": [ { "event": "click", "callback": function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttonhovercolor"]); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Disliked_button_hover_color" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttonhovercolor"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikedButtonOpacity", "rangetext", "SETTINGS_DISLIKEDBUTTON_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Disliked_button_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttonopacity"]); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "dislikedButtonHoverOpacity", "rangetext", "SETTINGS_DISLIKEDBUTTON_HOVER_OPACITY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Disliked_button_hover_opacity" ); option.addEventListener("update", function(){ ytcenter.classManagement.updateClassesByGroup(["dislikedbuttonopacity"]); }); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_RATINGBAR"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "sparkbarLikesColor", // defaultSetting "colorpicker", // module "SETTINGS_SPARKBAR_LIKES_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff"] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Rating_Bar_Likes_Color" ); option.addEventListener("update", function(){ var wvi = document.getElementById("watch7-views-info"), sl = document.getElementsByClassName("video-extras-sparkbar-likes"); if (sl && sl.length > 0 && sl[0]) { sl[0].style.background = ytcenter.settings.sparkbarLikesColor; } }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "sparkbarDislikesColor", // defaultSetting "colorpicker", // module "SETTINGS_SPARKBAR_DISLIKES_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff"] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Rating_Bar_Dislikes_Color" ); option.addEventListener("update", function(){ var wvi = document.getElementById("watch7-views-info"), sd = document.getElementsByClassName("video-extras-sparkbar-dislikes"); if (sd && sd.length > 0 && sd[0]) { sd[0].style.background = ytcenter.settings.sparkbarDislikesColor; } }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "sparkbarHeight", // defaultSetting "rangetext", // module "SETTINGS_SPARKBAR_HEIGHT", // label { "min": 1, "max": 100, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Height" ); option.addEventListener("update", function(){ var wvi = document.getElementById("watch7-views-info"), sl = document.getElementsByClassName("video-extras-sparkbar-likes"), sd = document.getElementsByClassName("video-extras-sparkbar-dislikes"); if (sl && sd && sl.length > 0 && sd.length > 0 && sl[0] && sd[0]) { sl[0].style.height = ytcenter.settings.sparkbarHeight + "px"; sd[0].style.height = ytcenter.settings.sparkbarHeight + "px"; sd[0].parentNode.style.height = ytcenter.settings.sparkbarHeight + "px"; } }); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_PLACEMENT"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableDownload", "bool", "SETTINGS_ENABLEDOWNLOAD_LABEL", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Placement" ); if (identifier === 8) option.setVisibility(false); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "enableRepeat", "bool", "SETTINGS_ENABLEREPEAT_LABEL", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Placement" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "lightbulbEnable", "bool", "SETTINGS_LIGHTBULB_ENABLE", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Placement" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "resizeEnable", "bool", "SETTINGS_RESIZE_ENABLE", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Placement" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "aspectEnable", "bool", "SETTINGS_ASPECT_ENABLE", { "listeners": [ { "event": "click", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Placement" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "newline" ); option.setVisibility(ytcenter.getPage() === "watch"); ytcenter.events.addEvent("ui-refresh", function(){ this.setVisibility(ytcenter.getPage() === "watch"); }.bind(option)); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "button", null, { "text": "SETTINGS_PLACEMENTSYSTEM_MOVEELEMENTS_LABEL" } ); var placementsystemToggler = false; var focus = null; option.addModuleEventListener("click", function placementToggleFunction(){ function save() { // Retrive the changed sort list and update the settings accordingly. var sortList = ytcenter.placementsystem.getSortList(ytcenter.placementsystem.placementGroupsReferenceList); //ytcenter.placementsystem.setSortList(sortList); ytcenter.settings.placementGroups = sortList; ytcenter.saveSettings(); placementToggleFunction(); } function cancel() { ytcenter.placementsystem.setSortList(ytcenter.settings.placementGroups, ytcenter.placementsystem.placementGroupsReferenceList); placementToggleFunction(); } placementsystemToggler = !placementsystemToggler; if (focus !== null) { focus(); focus = null; } ytcenter.placementsystem.setMoveable(placementsystemToggler); if (placementsystemToggler) { ytcenter.utils.addClass(document.body, "ytcenter-placementsystem-activated"); ytcenter.settingsPanelDialog.setVisibility(false); ytcenter.cssElements.elementFocus.add(); focus = ytcenter.elementfocus.focus(document.getElementById("watch8-action-buttons"), save, cancel); } else { ytcenter.cssElements.elementFocus.remove(); ytcenter.utils.removeClass(document.body, "ytcenter-placementsystem-activated"); ytcenter.settingsPanelDialog.setVisibility(true); } }); option.setVisibility(ytcenter.getPage() === "watch"); ytcenter.events.addEvent("ui-refresh", function(){ this.setVisibility(ytcenter.getPage() === "watch"); }.bind(option)); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "textContent", null, { "textlocale": "SETTINGS_PLACEMENTSYSTEM_MOVEELEMENTS_INSTRUCTIONS", "styles": { "margin-left": "20px" } } ); option.setVisibility(ytcenter.getPage() === "watch"); ytcenter.events.addEvent("ui-refresh", function(){ this.setVisibility(ytcenter.getPage() === "watch"); }.bind(option)); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_LIGHTSOFF"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "lightbulbAutoOff", // defaultSetting "bool", // module "SETTINGS_LIGHTBULB_AUTO", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Lights_Off" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "lightbulbClickThrough", // defaultSetting "bool", // module "SETTINGS_LIGHTBULB_CLICK_THROUGH", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Click_Through" ); option.addEventListener("update", function(){ ytcenter.tmp.lightoffwarning(); }); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "lightbulbBackgroundColor", // defaultSetting "colorpicker", // module "SETTINGS_LIGHTBULB_COLOR", { "presetColors": ["#000", "#fff", "#590", "#ccc", "#f00", "#2793e6", "#ff8f00"] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Light_Off_Color" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "lightbulbBackgroundOpaque", // defaultSetting "rangetext", // module "SETTINGS_LIGHTBULB_TRANSPARENCY", { "min": 0, "max": 100, "suffix": "%" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Light_Off_Opacity" ); subcat.addOption(option); (function(opt){ option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module null, { "textlocale": "SETTINGS_LIGHTBULB_WARNING", "styles": { "color": "#ff0000" } } ); if (ytcenter.settings.lightbulbBackgroundOpaque > 90 && ytcenter.settings.lightbulbClickThrough) { option.setVisibility(true); } else { option.setVisibility(false); } opt.addEventListener("update", (function(o){ ytcenter.tmp = ytcenter.tmp || {}; ytcenter.tmp.lightoffwarning = function(){ if (ytcenter.settings.lightbulbBackgroundOpaque > 90 && ytcenter.settings.lightbulbClickThrough) { o.setVisibility(true); } else { o.setVisibility(false); } }; return ytcenter.tmp.lightoffwarning; })(option), false); subcat.addOption(option); })(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_VIDEO_THUMBNAIL"); cat.addSubCategory(subcat); // Animation option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBNAIL_ANIMATION", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Animation" ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailAnimationEnabled", // defaultSetting "bool", // module "SETTINGS_THUMBNAIL_ANIMATION_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Animation" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailAnimationShuffle", // defaultSetting "bool", // module "SETTINGS_THUMBNAIL_ANIMATION_SHUFFLE", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Shuffle" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailAnimationDelay", // defaultSetting "rangetext", // module "SETTINGS_THUMBNAIL_ANIMATION_DELAY", // label { "min": 250, "max": 5250, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Delay" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailAnimationInterval", // defaultSetting "rangetext", // module "SETTINGS_THUMBNAIL_ANIMATION_INTERVAL", // label { "min": 0, "max": 5000, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Interval" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailAnimationFallbackInterval", // defaultSetting "rangetext", // module "SETTINGS_THUMBNAIL_ANIMATION_FALLBACK_INTERVAL", // label { "min": 0, "max": 5000, "suffix": " ms" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Fallback_Interval" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); // Quality option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBVIDEO_QUALITY", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Quality-2" // help ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualityBar", // defaultSetting "bool", // module "SETTINGS_THUMBVIDEO_QUALITY_ENABLE" // label ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualitySeparated", // defaultSetting "bool", // module "SETTINGS_THUMBVIDEO_QUALITY_DASHNONDASHSEPARATED", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Separate_DASH_and_nonDASH_formats" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualityFPS", // defaultSetting "bool", // module "SETTINGS_THUMBVIDEO_QUALITY_FPS" // label ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualityPosition", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_POSITION", // label { // args "list": [ { "value": "topleft", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPLEFT" }, { "value": "topright", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPRIGHT" }, { "value": "bottomleft", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMLEFT" }, { "value": "bottomright", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMRIGHT" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualityDownloadAt", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_DOWNLOAD", // label { // args "list": [ { "value": "page_start", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONSTART" }, { "value": "scroll_into_view", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_INVIEW" }, { "value": "hover_thumbnail", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailQualityVisible", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_VISIBLE", // label { // args "list": [ { "value": "always", "label": "SETTINGS_THUMBVIDEO_ALWAYSVISIBLE" }, { "value": "show_hover", "label": "SETTINGS_THUMBVIDEO_SHOWONHOVER" }, { "value": "hide_hover", "label": "SETTINGS_THUMBVIDEO_HIDEONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); // Rating bar option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBVIDEO_RATING_BAR", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#rating-bar" // help ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBar", // defaultSetting "bool", // module "SETTINGS_THUMBVIDEO_RATING_BAR_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Rating_Bar-2" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarPosition", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_POSITION", // label { // args "list": [ { "value": "top", "label": "SETTINGS_THUMBVIDEO_POSITION_TOP" }, { "value": "bottom", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOM" }, { "value": "left", "label": "SETTINGS_THUMBVIDEO_POSITION_LEFT" }, { "value": "right", "label": "SETTINGS_THUMBVIDEO_POSITION_RIGHT" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarDownloadAt", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_DOWNLOAD", // label { // args "list": [ { "value": "page_start", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONSTART" }, { "value": "scroll_into_view", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_INVIEW" }, { "value": "hover_thumbnail", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarVisible", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_VISIBLE", // label { // args "list": [ { "value": "always", "label": "SETTINGS_THUMBVIDEO_ALWAYSVISIBLE" }, { "value": "show_hover", "label": "SETTINGS_THUMBVIDEO_SHOWONHOVER" }, { "value": "hide_hover", "label": "SETTINGS_THUMBVIDEO_HIDEONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarLikesColor", // defaultSetting "colorpicker", // module "SETTINGS_THUMBNAIL_SPARKBAR_LIKES_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff"] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Likes_Color" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarDislikesColor", // defaultSetting "colorpicker", // module "SETTINGS_THUMBNAIL_SPARKBAR_DISLIKES_COLOR", { "presetColors": ["#590", "#ccc", "#f00", "#2793e6", "#ff8f00", "#fff"] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Disikes_Color" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsBarHeight", // defaultSetting "rangetext", // module "SETTINGS_SPARKBAR_HEIGHT", // label { "min": 1, "max": 100, "suffix": "px" }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Height-2" ); option.setStyle("margin-left", "12px"); subcat.addOption(option); // Rating count option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBVIDEO_RATING_COUNT", // label null, // args "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Rating_Count" // help ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsCount", // defaultSetting "bool", // module "SETTINGS_THUMBVIDEO_RATING_COUNT_ENABLE" // label ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsCountPosition", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_POSITION", // label { // args "list": [ { "value": "topleft", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPLEFT" }, { "value": "topright", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPRIGHT" }, { "value": "bottomleft", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMLEFT" }, { "value": "bottomright", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMRIGHT" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsCountDownloadAt", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_DOWNLOAD", // label { // args "list": [ { "value": "page_start", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONSTART" }, { "value": "scroll_into_view", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_INVIEW" }, { "value": "hover_thumbnail", "label": "SETTINGS_THUMBVIDEO_DOWNLOAD_ONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailRatingsCountVisible", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_VISIBLE", // label { // args "list": [ { "value": "always", "label": "SETTINGS_THUMBVIDEO_ALWAYSVISIBLE" }, { "value": "show_hover", "label": "SETTINGS_THUMBVIDEO_SHOWONHOVER" }, { "value": "hide_hover", "label": "SETTINGS_THUMBVIDEO_HIDEONHOVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); // Watch later button option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBVIDEO_WATCH_LATER", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Watch_Later_Button" ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailWatchLaterPosition", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_POSITION", // label { "list": [ { "value": "topleft", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPLEFT" }, { "value": "topright", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPRIGHT" }, { "value": "bottomleft", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMLEFT" }, { "value": "bottomright", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMRIGHT" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailWatchLaterVisible", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_VISIBLE", // label { // args "list": [ { "value": "always", "label": "SETTINGS_THUMBVIDEO_ALWAYSVISIBLE" }, { "value": "show_hover", "label": "SETTINGS_THUMBVIDEO_SHOWONHOVER" }, { "value": "hide_hover", "label": "SETTINGS_THUMBVIDEO_HIDEONHOVER" }, { "value": "never", "label": "SETTINGS_THUMBVIDEO_NEVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); // Time code option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module "SETTINGS_THUMBVIDEO_TIME_CODE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Time_Code" ); option.setStyle("font-weight", "bold"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailTimeCodePosition", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_POSITION", // label { // args "list": [ { "value": "topleft", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPLEFT" }, { "value": "topright", "label": "SETTINGS_THUMBVIDEO_POSITION_TOPRIGHT" }, { "value": "bottomleft", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMLEFT" }, { "value": "bottomright", "label": "SETTINGS_THUMBVIDEO_POSITION_BOTTOMRIGHT" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "videoThumbnailTimeCodeVisible", // defaultSetting "list", // module "SETTINGS_THUMBVIDEO_VISIBLE", // label { // args "list": [ { "value": "always", "label": "SETTINGS_THUMBVIDEO_ALWAYSVISIBLE" }, { "value": "show_hover", "label": "SETTINGS_THUMBVIDEO_SHOWONHOVER" }, { "value": "hide_hover", "label": "SETTINGS_THUMBVIDEO_HIDEONHOVER" }, { "value": "never", "label": "SETTINGS_THUMBVIDEO_NEVER" } ], "listeners": [ { "event": "update", "callback": function(){ ytcenter.events.performEvent("ui-refresh"); } } ] } ); option.setStyle("margin-left", "12px"); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_COMMENTS"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableComments", "bool", "SETTINGS_COMMENTS_ENABLE" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryEnabled", // defaultSetting "bool", // module "SETTINGS_COMMENTS_COUNTRY_ENABLE", // label null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Country_For_Comments" // help ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryShowFlag", // defaultSetting "bool", // module "SETTINGS_COMMENTS_COUNTRY_SHOW_FLAG", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Show_Country_Flag-2" // label ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryUseNames", // defaultSetting "bool", // module "SETTINGS_COMMENTS_COUNTRY_USE_NAME", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Use_Country_Names-2" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryLazyLoad", // defaultSetting "bool", // module "SETTINGS_COMMENTS_COUNTRY_LAZY_LOAD", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Lazy_Load" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryButtonLoad", // defaultSetting "bool", // module "SETTINGS_COMMENTS_COUNTRY_BUTTON_LOAD", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#Load_by_button" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "commentCountryPosition", // defaultSetting "list", // module "SETTINGS_COMMENTS_COUNTRY_POSITION", // label { "list": [ { "value": "before_username", "label": "SETTINGS_COMMENTS_COUNTRY_POSITION_BEFORE_USERNAME" }, { "value": "after_username", "label": "SETTINGS_COMMENTS_COUNTRY_POSITION_AFTER_USERNAME" }, { "value": "last", "label": "SETTINGS_COMMENTS_COUNTRY_POSITION_LAST" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Comment_Country_Position" ); subcat.addOption(option); /* Not needed as of now subcat = ytcenter.settingsPanel.createSubCategory("Subscriptions"); cat.addSubCategory(subcat); */ /* Category:Update */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_UPDATE"); if (!devbuild) { if ((identifier === 1 && (uw.navigator.userAgent.indexOf("Opera") !== -1 || uw.navigator.userAgent.indexOf("OPR/") !== -1)) || identifier === 6 || identifier === 8) { cat.setVisibility(false); } ytcenter.events.addEvent("ui-refresh", function(){ if ((identifier === 1 && (uw.navigator.userAgent.indexOf("Opera") !== -1 || uw.navigator.userAgent.indexOf("OPR/") !== -1)) || identifier === 6 || identifier === 8) { this.setVisibility(false); } else { this.setVisibility(true); } }.bind(cat)); } subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_TAB_GENERAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "enableUpdateChecker", "bool", "SETTINGS_UPDATE_ENABLE", null, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Enable_Update_Checker" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( "updateCheckerInterval", "list", "SETTINGS_UPDATE_INTERVAL", { "list": [ { "value": "0", "label": "SETTINGS_UPDATE_INTERVAL_ALWAYS" }, { "value": "1", "label": "SETTINGS_UPDATE_INTERVAL_EVERYHOUR" }, { "value": "2", "label": "SETTINGS_UPDATE_INTERVAL_EVERY2HOUR" }, { "value": "12", "label": "SETTINGS_UPDATE_INTERVAL_EVERY12HOUR" }, { "value": "24", "label": "SETTINGS_UPDATE_INTERVAL_EVERYDAY" }, { "value": "48", "label": "SETTINGS_UPDATE_INTERVAL_EVERY2DAY" }, { "value": "168", "label": "SETTINGS_UPDATE_INTERVAL_EVERYWEEK" }, { "value": "336", "label": "SETTINGS_UPDATE_INTERVAL_EVERY2WEEK" }, { "value": "720", "label": "SETTINGS_UPDATE_INTERVAL_EVERYMONTH" } ] }, "https://github.com/YePpHa/YouTubeCenter/wiki/Features#wiki-Update_Interval" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, "button", null, { "text": "SETTINGS_UPDATE_CHECKFORNEWUPDATES", "listeners": [ { "event": "click", "callback": function(){ this.textContent = ytcenter.language.getLocale("SETTINGS_UPDATE_CHECKINGFORNEWUPDATES"); this.disabled = true; ytcenter.checkForUpdates((function(self){ return function(){ self.textContent = ytcenter.language.getLocale("SETTINGS_UPDATE_CHECKFORNEWUPDATESSUCCESS"); self.disabled = false; }; })(this), (function(self){ return function(){ self.textContent = ytcenter.language.getLocale("SETTINGS_UPDATE_CHECKINGFORNEWUPDATESERROR"); self.disabled = false; }; })(this), (function(self){ return function(){ self.textContent = ytcenter.language.getLocale("SETTINGS_UPDATE_CHECKINGFORNEWUPDATESDISABLED"); self.disabled = true; }; })(this)); } } ] } ); subcat.addOption(option); /* DISABLED until implemented subcat = ytcenter.settingsPanel.createSubCategory("Channel"); cat.addSubCategory(subcat); */ /* Category:Debug */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_DEBUG"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_LOG"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "debugConsole", // defaultSetting "bool", // module "SETTINGS_DEBUG_CONSOLE" ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textarea", null, { "styles": { "width": "100%", "height": "130px", "background-color": "#fff", "border": "1px solid #ccc" } } ); subcat.addOption(option); subcat.addEventListener("click", (function(opt){ return function(){ con.log("[Debug] Loading debug log..."); var module = opt.getLiveModule(); if (module) { module.setText(ytcenter.language.getLocale("SETTINGS_DEBUG_LOADING")); uw.setTimeout(function(){ module.setText(ytcenter.getDebug()); module.selectAll(); }, 100); } }; })(option)); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "button", null, { "text": "SETTINGS_DEBUG_CREATEGIST", "listeners": [ { "event": "click", "callback": function() { var content = document.createElement("div"); var data = { "description": null, "public": true, "files": { "debug.txt": { "content": ytcenter.getDebug() } } }; if (devbuild) { data.description = "YouTube Center v" + devnumber + " Debug Info"; } else { data.description = "YouTube Center ".concat(ytcenter.version, "-", ytcenter.revision, " Debug Info"); } var text = document.createElement("p"); text.appendChild(document.createTextNode(ytcenter.language.getLocale("GIST_TEXT"))); text.setAttribute("style", "margin-bottom: 10px"); content.appendChild(text); var gistURL = document.createElement("input"); gistURL.setAttribute("type", "text"); gistURL.setAttribute("class", "yt-uix-form-input-text"); gistURL.setAttribute("value", ytcenter.language.getLocale("GIST_LOADING")); gistURL.setAttribute("readonly", "readonly"); ytcenter.utils.addEventListener(gistURL, "focus", function() { this.select(); }, false); content.appendChild(gistURL); ytcenter.dialog("GIST_TITLE", content).setVisibility(true); 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(response) { var details = JSON.parse(response.responseText); gistURL.value = details.html_url; } }); } } ] } ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_EXPERIMENTS"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( "YouTubeExperiments", // defaultSetting "layoutExperiments" ); subcat.addEventListener("click", (function(opt){ return function(){ var module = opt.getLiveModule(); if (module && !module.hasLoadedOnce()) { module.loadExperiments(); } }; })(option)); subcat.addOption(option); //subcat = ytcenter.settingsPanel.createSubCategory("Options"); cat.addSubCategory(subcat); /* Category:Share DISABLED until I implement it*/ /*cat = ytcenter.settingsPanel.createCategory("Share"); subcat = ytcenter.settingsPanel.createSubCategory("Share"); cat.addSubCategory(subcat); */ /* Category:Donate */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_DONATE"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_DONATE"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module null, // label { "textlocale": "SETTINGS_DONATE_TEXT", "replace": { "{wiki-donate}": function(){ var a = document.createElement("a"); a.setAttribute("target", "_blank"); a.setAttribute("href", "https://github.com/YePpHa/YouTubeCenter/wiki/Donate"); a.textContent = ytcenter.language.getLocale("SETTINGS_DONATE_WIKI"); ytcenter.language.addLocaleElement(a, "SETTINGS_DONATE_WIKI", "@textContent"); return a; } } } ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_PAYPAL"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "textContent", // module null, // label { "textlocale": "SETTINGS_DONATE_PAYPAL_TEXT2", "replace": { "{page-link}": function(){ var a = document.createElement("a"); a.setAttribute("target", "_blank"); a.setAttribute("href", "https://dl.dropboxusercontent.com/u/13162258/YouTube%20Center/support/PayPal.html"); a.textContent = ytcenter.language.getLocale("SETTINGS_DONATE_PAYPAL_LINK2"); ytcenter.language.addLocaleElement(a, "SETTINGS_DONATE_PAYPAL_LINK2", "@textContent"); return a; } } } ); subcat.addOption(option); /* Category:About */ cat = ytcenter.settingsPanel.createCategory("SETTINGS_CAT_ABOUT"); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_ABOUT"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "aboutText", // module null // label ); subcat.addOption(option); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "link", // module null, // label { "titleLocale": "SETTINGS_ABOUT_LINKS", "links": [ {text: "Wiki", url: "https://github.com/YePpHa/YouTubeCenter/wiki"}, {text: "Facebook", url: "https://www.facebook.com/YouTubeCenter"}, {text: "Google+", url: "https://plus.google.com/111275247987213661483/posts"}, {text: "Firefox", url: "https://addons.mozilla.org/en-us/firefox/addon/youtube-center/"}, {text: "Opera", url: "https://addons.opera.com/en/extensions/details/youtube-center/"}, {text: "Maxthon", url: "http://extension.maxthon.com/detail/index.php?view_id=1201"}, {text: "Github", url: "https://github.com/YePpHa/YouTubeCenter/"} ] } ); subcat.addOption(option); subcat = ytcenter.settingsPanel.createSubCategory("SETTINGS_SUBCAT_TRANSLATORS"); cat.addSubCategory(subcat); option = ytcenter.settingsPanel.createOption( null, // defaultSetting "translators", // module null, // label { // args "translators": { "ar-BH": [ { name: "alihill381" } ], "bg-BG": [ { name: "Mani Farone" } ], "ca-ES": [ { name: "Joan Alemany" }, { name: "Raül Cambeiro" } ], "cs-CZ": [ { name: "Petr Vostřel", url: "http://petr.vostrel.cz/" }, { name: "R3gi", url: "mailto:regiprogi@gmail.com" } ], "da-DK": [ { name: "Lasse Olsen" }, { name: "Jeppe Rune Mortensen", url: "https://github.com/YePpHa/" } ], "de-DE": [ { name: "Simon Artmann" }, { name: "Sven \"Hidden\" W" } ], "en-US": [], "es-ES": [ { name: "Roxz" } ], "fa-IR": [], "fr-FR": [ { name: "ThePoivron", url: "http://www.twitter.com/DaPavron" } ], "he-IL": [ { name: "baryoni" } ], "hu-HU": [ { name: "Eugenox" }, { name: "Mateus" } ], "it-IT": [ { name: "Pietro De Nicolao" } ], "ja-JP": [ { name: "Lightning-Natto" } ], "ko-KR": [ { name: "Hyeongi Min", url: "https://www.facebook.com/MxAiNM" }, { name: "U Bless", url: "http://userscripts.org/users/ubless" } ], "no-NO": [ { name: "master3395", url: "https://www.youtube.com/user/master33951" }, { name: "Mathias Solheim", url: "http://mathias.ocdevelopment.net/" } ], "nl-NL": [ { name: "Marijn Roes" } ], "pl-PL": [ { name: "Piotr" }, { name: "kasper93" }, { name: "Piter432" } ], "pt-BR": [ { name: "Thiago R. M. Pereira" }, { name: "José Junior" }, { name: "Igor Rückert" } ], "pt-PT": [ { name: "Rafael Damasceno", url: "http://userscripts.org/users/264457" }, { name: "João P. Moutinho Barbosa" } ], "ro-RO": [ { name: "BlueMe", url: "http://www.itinerary.ro/" } ], "ru-RU": [ { name: "KDASOFT", url: "http://kdasoft.narod.ru/" } ], "sk-SK": [ { name: "ja1som" } ], "sv-SE": [ { name: "Christian Eriksson" } ], "tr-TR": [ { name: "Ismail Aksu" } ], "uk-UA": [ { name: "SPIDER-T1" }, { name: "Petro Lomaka", url: "https://plus.google.com/103266219992558963899/" } ], "vi-VN": [ { name: "Tuấn Phạm" } ], "zh-CN": [ { name: "雅丶涵", url: "http://www.baidu.com/p/%E9%9B%85%E4%B8%B6%E6%B6%B5" }, { name: "MatrixGT" } ], "zh-TW": [ { name: "泰熊" } ] } } ); subcat.addOption(option); }; settingsInit(); ytcenter.video = {}; uw.ytcenter._video = ytcenter.video; ytcenter.video.format = [ { type: 'video/mp4', name: 'SETTINGS_DOWNLOADFORMAT_LIST_MP4', key: 'mp4' }, { type: 'video/webm', name: 'SETTINGS_DOWNLOADFORMAT_LIST_WEBM', key: 'webm' }, { type: 'video/x-flv', name: 'SETTINGS_DOWNLOADFORMAT_LIST_FLV', key: 'flv' }, { type: 'video/3gpp', name: 'SETTINGS_DOWNLOADFORMAT_LIST_3GP', key: '3gp' }, { type: 'audio/mp4', name: 'SETTINGS_DOWNLOADFORMAT_LIST_AUDIO', key: 'm4a', help: 'https://github.com/YePpHa/YouTubeCenter/wiki/Download:Audio' } ]; ytcenter.video.resolutions = { 'tiny': '144p', 'small': '240p', 'medium': '360p', 'large': '480p', 'hd720': '720p', 'hd1080': '1080p', 'hd1440': '1440p', 'highres': 'Original' }; ytcenter.video.id = ""; ytcenter.video.title = ""; ytcenter.video.author = ""; ytcenter.video.channelname = ""; ytcenter.video._channel = {}; ytcenter.video.mimetypes = [ { mimetype: "video/webm", extension: ".webm" }, { mimetype: "video/x-flv", extension: ".flv" }, { mimetype: "video/mp4", extension: ".mp4" }, { mimetype: "video/3gpp", extension: ".3gp" }, { mimetype: "audio/mp4", extension: ".m4a" }, { mimetype: "audio/mp4", extension: ".m4a" } ]; ytcenter.video.getFilenameExtension = function(stream){ if (!stream || !stream.type || stream.type.indexOf(";") === -1) return ""; var mt = stream.type.split(";")[0], i; for (i = 0; i < ytcenter.video.mimetypes.length; i++) { if (ytcenter.video.mimetypes[i].mimetype === mt) return ytcenter.video.mimetypes[i].extension; } return ""; }; ytcenter.video.removeNonAlphanumericCharacters = function(text){ if (ytcenter.settings.fixfilename) { var buffer = ""; for (var i = 0, len = text.length; i < len; i++) { if (text.charAt(i).match(/[0-9a-zA-Z ]/i)) { buffer += text.charAt(i); } } return buffer; } else { return text; } }; ytcenter.video.getFilename = function(stream){ if (stream == null) return ""; var duration = 0; var pubtimestamp = 0, pubsecs = 0, pubmins = 0, pubhours = 0, pubdays = 0, pubmonth = 0, pubyear = 0; var nowtimestamp = 0, nowsecs = 0, nowmins = 0, nowhours = 0, nowdays = 0, nowmonth = 0, nowyear = 0; var durmin = 0; var dursec = 0; try { duration = ytcenter.player.getConfig().args.length_seconds; durmin = Math.floor(duration/60); dursec = duration - durmin*60; } catch (e) { duration = 0; durmin = 0; dursec = 0; } try { pubtimestamp = Math.floor(ytcenter.video.published.getTime()/1000); pubsecs = ytcenter.video.published.getSeconds(); pubmins = ytcenter.video.published.getMinutes(); pubhours = ytcenter.video.published.getHours(); pubdays = ytcenter.video.published.getDate(); pubmonth = ytcenter.video.published.getMonth() + 1; pubyear = ytcenter.video.published.getFullYear(); } catch (e) { pubtimestamp = 0; pubsecs = 0; pubmins = 0; pubhours = 0; pubdays = 0; pubmonth = 0; pubyear = 0; } try { var now = new Date(); nowtimestamp = Math.floor(now.getTime()/1000); nowsecs = now.getSeconds(); nowmins = now.getMinutes(); nowhours = now.getHours(); nowdays = now.getDate(); nowmonth = now.getMonth() + 1; nowyear = now.getFullYear(); } catch (e) { con.error(e); nowtimestamp = 0; nowsecs = 0; nowmins = 0; nowhours = 0; nowdays = 0; nowmonth = 0; nowyear = 0; } var filename = ytcenter.utils.replaceTextAsString(ytcenter.settings.filename, { title: ytcenter.video.removeNonAlphanumericCharacters(ytcenter.video.title), videoid: ytcenter.video.id, author: ytcenter.video.removeNonAlphanumericCharacters(ytcenter.video.author), channelname: ytcenter.video.removeNonAlphanumericCharacters(ytcenter.video.channelname), resolution: (ytcenter.video.resolutions.hasOwnProperty(stream.quality) ? ytcenter.video.resolutions[stream.quality] : ''), itag: stream.itag, dimension: (stream.dimension ? stream.dimension : stream.size), bitrate: stream.bitrate, width: (stream.dimension ? stream.dimension.split("x")[0] : (stream.size ? stream.size.split("x")[0] : 0)), height: (stream.dimension ? stream.dimension.split("x")[1] : (stream.size ? stream.size.split("x")[1] : 0)), format: (function(){ 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 ""; })(), quality: stream.quality, type: stream.type, dur: duration, durmins: ytcenter.utils.prefixText(durmin, "0", 2), dursecs: ytcenter.utils.prefixText(dursec, "0", 2), nowtimestamp: nowtimestamp, nowsecs: ytcenter.utils.prefixText(nowsecs, "0", 2), nowmins: ytcenter.utils.prefixText(nowmins, "0", 2), nowhours: ytcenter.utils.prefixText(nowhours, "0", 2), nowdays: ytcenter.utils.prefixText(nowdays, "0", 2), nowmonth: ytcenter.utils.prefixText(nowmonth, "0", 2), nowyear: nowyear, pubtimestamp: pubtimestamp, pubsecs: ytcenter.utils.prefixText(pubsecs, "0", 2), pubmins: ytcenter.utils.prefixText(pubmins, "0", 2), pubhours: ytcenter.utils.prefixText(pubhours, "0", 2), pubdays: ytcenter.utils.prefixText(pubdays, "0", 2), pubmonth: ytcenter.utils.prefixText(pubmonth, "0", 2), pubyear: pubyear }); // Removing illegal characters for filename for OS if (uw.navigator.appVersion.toLowerCase().indexOf("win") != -1) { filename = filename.replace(new RegExp('[\\\\/:|]+', 'g'), "-"); filename = filename.replace(new RegExp('["*?<>]+', 'g'), "_"); } else if (uw.navigator.appVersion.toLowerCase().indexOf("mac") != -1) { filename = filename.replace(new RegExp('^\\.'), "_"); filename = filename.replace(":", "-"); } else if (uw.navigator.appVersion.toLowerCase().indexOf("linux") != -1) { filename = filename.replace(new RegExp('[/\0]+', 'g'), "-"); } return filename; }; ytcenter.video.filename = function(stream){ if (stream == null) return ""; return stream.url + "&title=" + encodeURIComponent(ytcenter.video.getFilename(stream)); }; ytcenter.video.downloadLink = function(stream){ return ytcenter.video.filename(stream) + "&cpn=" + encodeURIComponent(ytcenter.utils.crypt()) + (stream.s || stream.sig ? "&signature=" + encodeURIComponent(stream.sig || ytcenter.utils.signatureDecipher(stream.s)) : ""); }; ytcenter.video.download = (function(){ var _download_iframe = null; return function(itag){ con.log("Downloading format " + itag + "..."); var stream = null; for (var i = 0; i < ytcenter.video.streams.length; i++) { if (ytcenter.video.streams[i].itag === itag && typeof ytcenter.video.streams[i].url != "undefined") { stream = ytcenter.video.streams[i]; break; } } if (stream) { if (!_download_iframe) { // Initalize iframe if it doesn't exist _download_iframe = document.createElement("iframe"); _download_iframe.style.position = "absolute"; _download_iframe.style.top = "-1000px"; _download_iframe.style.left = "-1000px"; _download_iframe.style.width = "1px"; _download_iframe.style.height = "1px"; document.body.appendChild(_download_iframe); } _download_iframe.setAttribute("src", ytcenter.video.downloadLink(stream)); } else { con.log("Format (" + itag + ") not found and therefore couldn't start downloading"); throw "Stream (" + itag + ") not found!"; } }; })(); ytcenter.video.streams = []; ytcenter.site = {}; ytcenter.site.removeAdvertisement = function(cfg){ cfg = cfg || ytcenter.player.getConfig(); var _ads = [ "supported_without_ads", "ad3_module", "adsense_video_doc_id", "allowed_ads", "baseUrl", "cafe_experiment_id", "afv_inslate_ad_tag", "advideo", "ad_device", "ad_channel_code_instream", "ad_channel_code_overlay", "ad_eurl", "ad_flags", "ad_host", "ad_host_tier", "ad_logging_flag", "ad_preroll", "ad_slots", "ad_tag", "ad_video_pub_id", "aftv", "afv", "afv_ad_tag", "afv_instream_max", "afv_ad_tag_restricted_to_instream", "afv_video_min_cpm", "dynamic_allocation_ad_tag", "pyv_ad_channels", "max_dynamic_allocation_ad_tag_length", "midroll_freqcap", "invideo", "instream", "pyv_in_related_cafe_experiment_id" ]; for (var i = 0; i < _ads.length; i++) { try { delete cfg.args[_ads[i]]; } catch (e) { con.error(e); } } try { if (cfg.args.csi_page_type) { con.log("Chaning csi_page_type from " + cfg.args.csi_page_type + " to watch, watch7"); if (ytcenter.watch7) { if (ytcenter.html5) { cfg.args.csi_page_type = "watch, watch7_html5"; } else { cfg.args.csi_page_type = "watch, watch7"; } } else { cfg.args.csi_page_type = "watch"; } } } catch (e) { con.error(e); } try { if (document.getElementById("watch-channel-brand-div")) { ytcenter.discardElement(document.getElementById("watch-channel-brand-div")); } } catch (e) { con.error(e); } try { var adBadges = ytcenter.utils.toArray(document.getElementsByClassName("yt-badge-ad")); for (var i = 0, len = adBadges.length; i < len; i++) { var parent = adBadges; while ((parent = parent.parentNode) !== null) { if (parent.tagName === "LI") { parent.parentNode.removeChild(parent); break; } } } } catch (e) { con.error(e); } return cfg; }; ytcenter.user = {}; ytcenter.user.callChannelFeed = function(username, callback){ ytcenter.utils.xhr({ method: "GET", url: 'https://gdata.youtube.com/feeds/api/channels?q=' + encodeURIComponent("\"" + username + "\"") + '&start-index=1&max-results=1&v=2&alt=json', headers: { "Content-Type": "text/plain" }, onload: function(response){ if (response.responseText) { var j = JSON.parse(response.responseText); if (j.feed && j.feed.entry && j.feed.entry.length > 0) { callback.apply(j.feed.entry[0]); } } } }); }; ytcenter.gridview = (function(){ function getFeed() { return document.getElementById("feed") || document.getElementById("browse-items-primary"); } function getIndividualFeed(feed) { if (feed && feed.children && feed.children.length > 0 && feed.children[0]) { return feed.children[0]; } return null; } function getFeedName(feed) { var individualFeed = getIndividualFeed(feed); if (individualFeed && individualFeed.getAttribute) { return individualFeed.getAttribute("data-feed-name"); } return null; } function getFeedType(feed) { var individualFeed = getIndividualFeed(feed), type = null; if (individualFeed && individualFeed.getAttribute) { type = individualFeed.getAttribute("data-feed-type"); } return type; } function getFeedItems(feed) { var items = []; if (feed && feed.getElementsByClassName) { var feedContainer = feed.getElementsByClassName("feed-item-container"); for (var i = 0, len = feedContainer.length; i < len; i++) { items.push(parseFeedItem(feedContainer[i])); } } return items; } function parseFeedItem(item) { var details = {}, aElm = item.getElementsByTagName("a"); if (aElm && aElm[0] && aElm[0].getAttribute) { var images = aElm[0].getElementsByTagName("img"); details.channelURL = aElm[0].getAttribute("href"); if (images && images.length > 0 && images[0] && images[0].getAttribute) { details.channelName = images[0].getAttribute("alt"); } } else { details.channelURL = null; details.channelName = null; } details.wrapper = item; details.metadata = item.getElementsByClassName("yt-lockup-meta")[0]; details.channelVerified = (item.getElementsByClassName("yt-user-name-icon-verified").length > 0); details.bubbleContainer = item.getElementsByClassName("feed-author-bubble-container")[0]; details.bubbleElement = item.getElementsByClassName("feed-author-bubble")[0]; if (item.getElementsByClassName("yt-user-name").length > 0) { details.usernameElement = item.getElementsByClassName("yt-user-name")[0]; details.ownerElement = details.usernameElement.parentNode; details.ownerElementListItem = (details.ownerElement.tagName === "LI"); details.usernamePrefixNode = null; if (details.usernameElement.previousSibling && details.usernameElement.previousSibling.nodeType === 3) { details.usernamePrefixNode = details.usernameElement.previousSibling; } } else { details.usernameElement = null; details.ownerElement = null; details.usernamePrefixNode = null; } return details; } function createOwnerElement(details) { var b = details.bubbleElement.cloneNode(false); b.textContent = details.channelName; b.className = b.className.replace("feed-author-bubble", ""); return b; } function isEnabled(feed) { feed = feed || getFeed(); return (loc.pathname.indexOf("/feed/subscriptions") === 0 && ytcenter.settings.gridSubscriptionsPage) || (getFeedType(feed) === "collection" && ytcenter.settings.gridCollectionPage); } function delayedUpdate() { con.log("[GridView] delayedUpdate called..."); if (loc.pathname.indexOf("/feed/") === 0) { var feed = getFeed(), observer = ytcenter.mutation.observe(feed, { childList: true, subtree: true }, function(){ con.log("[GridView] Mutation Observed... disconnecting!"); update(); observer.disconnect(); }); } } function update() { if (loc.pathname.indexOf("/feed/") === 0) { var feed = getFeed(); if (isEnabled(feed)) { var items = getFeedItems(feed); var ownerElm = null; var ownerWrapper = null; var details = null; for (var i = 0; i < items.length; i++) { details = items[i]; if (!ytcenter.utils.inArray(feedItems, details.wrapper)) { feedItems.push(details.wrapper); if (details.ownerElement) { ownerElm = details.ownerElement.cloneNode(true); if (details.ownerElementListItem) { details.ownerElement.parentNode.removeChild(details.ownerElement); } if (details.usernamePrefixNode) { ownerElm.removeChild(ownerElm.firstChild); } } else { ownerElm = createOwnerElement(items[i]); } ownerWrapper = document.createElement("div"); ownerWrapper.className = "ytcenter-grid-subscriptions-username"; var ownerElmChildren = null; if (details.ownerElementListItem) { var frag = document.createDocumentFragment(); ownerElmChildren = ytcenter.utils.toArray(ownerElm.children); var j; for (j = 0; j < ownerElmChildren.length; j++) { frag.appendChild(ownerElmChildren[j]); } ownerElm = frag; } ownerWrapper.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("SUBSCRIPTIONSGRID_BY_USERNAME"), {"{username}": ownerElm})); ytcenter.events.addEvent("language-refresh", (function(oW, oE, oEC){ return function(){ if (oEC) { var frag = document.createDocumentFragment(); var j; for (j = 0; j < oEC.length; j++) { frag.appendChild(oEC[j]); } oE = frag; } oW.innerHTML = ""; oW.appendChild(ytcenter.utils.replaceText(ytcenter.language.getLocale("SUBSCRIPTIONSGRID_BY_USERNAME"), {"{username}": oE})); }; })(ownerWrapper, ownerElm, ownerElmChildren)); details.ownerWrapper = ownerWrapper; details.metadata.parentNode.insertBefore(ownerWrapper, details.metadata); } } } } } var feedItems = []; return { update: update, delayedUpdate: delayedUpdate, isEnabled: isEnabled }; })(); ytcenter.playlistAutoPlay = (function(){ /* We want the toggle button */ function getToggleAutoPlayButton() { var playlist = document.getElementById("watch-appbar-playlist"); if (playlist) { var playlistToggleButton = playlist.getElementsByClassName("toggle-autoplay"); if (playlistToggleButton && playlistToggleButton.length > 0 && playlistToggleButton[0]) { playlistToggleButton = playlistToggleButton[0]; } else { playlistToggleButton = null; } return playlistToggleButton; } return null; } function setInitialAutoPlayState(state) { var playlist = document.getElementById("watch-appbar-playlist"); if (playlist) { var content = playlist.getElementsByClassName("playlist-header-content"); if (content.length > 0 && content[0]) { content[0].setAttribute("data-initial-autoplay-state", (state ? "true" : "false")); content[0].setAttribute("initial-autoplay-state", (state ? "true" : "false")); } } toggled = state; } function onToggleButtonClick() { toggled = !toggled; if (ytcenter.settings.playlistAutoPlayFreeze) return; ytcenter.settings.playlistAutoPlay = toggled; ytcenter.saveSettings(); ytcenter.events.performEvent("settings-update"); } function init() { if (ytcenter.playlist) { setInitialAutoPlayState(ytcenter.settings.playlistAutoPlay); var toggleButton = getToggleAutoPlayButton(); if (toggleButton) { ytcenter.utils.addEventListener(toggleButton, "click", onToggleButtonClick, false); } initState(); } } function initState() { var playlist = document.getElementById("watch-appbar-playlist"); if (playlist) { var toggleAutoplayButton = getToggleAutoPlayButton(); if (toggleAutoplayButton) { if (toggled) { ytcenter.utils.addClass(toggleAutoplayButton, "yt-uix-button-toggled"); } else { ytcenter.utils.removeClass(toggleAutoplayButton, "yt-uix-button-toggled"); } toggleAutoplayButton.setAttribute("data-button-toggle", (toggled ? "true" : "false")); } else { toggleAutoplayButton = document.createElement("button"); toggleAutoplayButton.className = "yt-uix-button yt-uix-button-size-default yt-uix-button-player-controls yt-uix-button-empty yt-uix-button-has-icon toggle-autoplay yt-uix-button-opacity yt-uix-tooltip yt-uix-tooltip" + (toggled ? " yt-uix-button-toggled" : ""); toggleAutoplayButton.setAttribute("type", "button"); toggleAutoplayButton.setAttribute("onclick", ";return false;"); toggleAutoplayButton.setAttribute("title", uw.yt.msgs_.YTP_AUTOPLAY); toggleAutoplayButton.setAttribute("data-button-toggle", (toggled ? "true" : "false")); toggleAutoplayButton.addEventListener("click", onToggleButtonClick, false); var iconWrapper = document.createElement("span"); iconWrapper.className = "yt-uix-button-icon-wrapper"; var icon = document.createElement("img"); icon.className = "yt-uix-button-icon yt-uix-button-icon-watch-appbar-autoplay yt-sprite"; icon.setAttribute("src", "//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif"); icon.setAttribute("title", uw.yt.msgs_.YTP_AUTOPLAY); iconWrapper.appendChild(icon); toggleAutoplayButton.appendChild(iconWrapper); var controls = playlist.getElementsByClassName("playlist-nav-controls"); controls && controls[0] && controls[0].appendChild && controls[0].appendChild(toggleAutoplayButton); } if (uw.yt && uw.yt.www && uw.yt.www.watch && uw.yt.www.watch.lists && uw.yt.www.watch.lists.getState) { if (uw.yt.www.watch.lists.getState !== getState) { getStateFunction = uw.yt.www.watch.lists.getState; uw.yt.www.watch.lists.getState = getState; } } else { con.log("[Playlist] getState not found!"); setTimeout(initState, 1000); } } } function getState() { var state = getStateFunction(); state.autoPlay = toggled; return state; } var getStateFunction = null; var timer = null; var toggled = false; return { init: init }; })(); ytcenter.player = {}; ytcenter.player.setPlaybackState = (function(){ function updateState(state, s) { con.log("[Player:setPlaybackState] Preferred state: " + state + ", current state: " + s); var api = ytcenter.player.getAPI(); var muted = false; if (s === 1) { if (state === 0) { api.mute(); api.stopVideo(); !ytcenter.settings.mute && api.isMuted && api.unMute(); } else if (state === 1) { api.playVideo(); } else if (state === 2) { api.mute(); api.pauseVideo(); !ytcenter.settings.mute && api.isMuted && api.unMute(); } ytcenter.player.listeners.removeEventListener("onStateChange", listener); if (!ytcenter.html5) { setState.preferredState = null; } } else if (s <= 0 && state === 2) { api.mute(); api.playVideo(); api.pauseVideo(); !ytcenter.settings.mute && api.isMuted && api.unMute(); ytcenter.player.listeners.removeEventListener("onStateChange", listener); if (!ytcenter.html5) { setState.preferredState = null; } } if (ytcenter.html5) { ytcenter.utils.asyncCall(function(){ var newState = api.getPlayerState(); if (newState !== state && (newState !== -1 && newState !== 5) && typeof newState === "number") { updateState(state, newState); } else { setState.preferredState = null; } }); } } function setState(state) { setState.preferredState = state; var api = ytcenter.player.getAPI(); con.log("[Player:setPlaybackState] State is changed to " + state); if (listener !== null) { ytcenter.player.listeners.removeEventListener("onStateChange", listener); } listener = ytcenter.utils.bindArgument(updateState, state); ytcenter.player.listeners.addEventListener("onStateChange", listener); updateState(state, api.getPlayerState()); } var listener = null; setState.preferredState = null; return setState; })(); ytcenter.player.setQuality = (function(){ function stateChange(vq, state) { api = ytcenter.player.getAPI(); if (api) { if (state === 1 && step === 0) { step = 1; api.setPlaybackQuality(vq); api.seekTo(api.getCurrentTime()); api.pauseVideo(); } else if (state === 2 && step === 1) { step = 2; api.setPlaybackQuality(vq); api.seekTo(api.getCurrentTime()); api.playVideo(); } else if (state === 1 && step === 2) { step = -1; api.setPlaybackQuality(vq); api.seekTo(api.getCurrentTime()); removeStateListener(); } } } function addStateListener(vq) { listener = ytcenter.utils.bindArgument(stateChange, vq); ytcenter.player.listeners.addEventListener("onStateChange", listener); addedListener = true; } function removeStateListener(vq) { ytcenter.player.listeners.removeEventListener("onStateChange", listener); listener = null; addedListener = false; } function reloadQuality(vq) { api = ytcenter.player.getAPI(); /* Forcing the quality */ step = 0; /* Starting the hack */ if (!addedListener) { addStateListener(); } /* Checking if the player is already playing the video. If that's the case then execute the stateChange with state set to 1 */ if (api.getPlayerState() === 1) { stateChange(vq, 1); } } function setQuality(vq) { api = ytcenter.player.getAPI(); if (api && typeof api.setPlaybackQuality === "function") { con.log("[Player:SetQuality] Setting quality to " + vq); api.setPlaybackQuality(vq); /* Setting the preferred quality. */ //reloadQuality(vq); } else { con.log("[Player:SetQuality] API not ready!"); } } var addedListener = false; var listener = null; var step = -1; var api = null; return setQuality; })(); ytcenter.player.isPreventAutoPlay = function(){ var notFocused = document && document.hasFocus && typeof document.hasFocus === "function" && !document.hasFocus(), preventAutoPlay = false, autoPlay = false; if (ytcenter.page === "watch") { autoPlay = ytcenter.settings.preventAutoPlay; } else if (ytcenter.page === "embed") { autoPlay = ytcenter.settings.embed_preventAutoPlay; } else if (ytcenter.page === "channel") { autoPlay = ytcenter.settings.channel_preventAutoPlay; } if (ytcenter.page === "watch" && notFocused && ((ytcenter.playlist && ytcenter.settings.preventTabPlaylistAutoPlay) || (!ytcenter.playlist && ytcenter.settings.preventTabAutoPlay))) { preventAutoPlay = true; } else { if (ytcenter.playlist && ytcenter.page === "watch") { preventAutoPlay = ytcenter.settings.preventPlaylistAutoPlay; } else { preventAutoPlay = autoPlay; } } return preventAutoPlay; }; ytcenter.player.isPreventAutoBuffering = function(){ var notFocused = document && document.hasFocus && typeof document.hasFocus === "function" && !document.hasFocus(), preventAutoBuffering = false, autoBuffering = false; if (ytcenter.page === "watch") { autoBuffering = ytcenter.settings.preventAutoBuffer; } else if (ytcenter.page === "embed") { autoBuffering = ytcenter.settings.embed_preventAutoBuffer; } else if (ytcenter.page === "channel") { autoBuffering = ytcenter.settings.channel_preventAutoBuffer; } if (ytcenter.page === "watch" && notFocused && ((ytcenter.playlist && ytcenter.settings.preventTabPlaylistAutoBuffer) || (!ytcenter.playlist && ytcenter.settings.preventTabAutoBuffer))) { preventAutoBuffering = true; } else { if (ytcenter.playlist && ytcenter.page === "watch") { preventAutoBuffering = ytcenter.settings.preventPlaylistAutoBuffer; } else { preventAutoBuffering = autoBuffering; } } return preventAutoBuffering; }; ytcenter.player.darkside = function(){ var player = document.getElementById("player"); var playlistTray = document.getElementById("playlist-tray"); var theaterBackground = document.getElementById("theater-background"); if (!theaterBackground && player) { theaterBackground = document.createElement("div"); theaterBackground.setAttribute("id", "theater-background"); player.insertBefore(theaterBackground, player.children[0]); } if (ytcenter.getPage() === "watch" && ytcenter.player.getCurrentPlayerSize().large) { if (ytcenter.settings.playerDarkSideBG) { if (theaterBackground && !ytcenter.settings.playerDarkSideBGRetro) { theaterBackground.style.backgroundColor = ytcenter.settings.playerDarkSideBGColor; } if (playlistTray) { playlistTray.style.top = "-" + ytcenter.player.getCurrentPlayerSize().playerHeight + "px"; } return true; } } if (theaterBackground) { theaterBackground.style.backgroundColor = ""; } if (playlistTray) { playlistTray.style.top = ""; } return false; }; ytcenter.player.network = {}; ytcenter.player.network.pause = function(){ con.log("[Tab Event] Calling player.pauseVideo();"); ytcenter.tabEvents.fireEvent("player", "pauseVideo"); }; ytcenter.player.setPlaybackQuality = function(preferredQuality){ function recall(vq){ if (vq === 1) { ytcenter.player.listeners.removeEventListener("onStateChange", recall); ytcenter.player.setPlaybackQuality(preferredQuality); } } var api = ytcenter.player.getAPI(), config = ytcenter.player.getConfig(); if (config && config.args) { config.args.vq = preferredQuality; } if (!api) { ytcenter.player.listeners.addEventListener("onStateChange", recall); } else { /*if (api.getPlaybackQuality() === preferredQuality && preferredQuality !== "small") api.setPlaybackQuality("small"); else if (api.getPlaybackQuality() === preferredQuality && preferredQuality !== "medium") api.setPlaybackQuality("medium");*/ ytcenter.player.setQuality(preferredQuality); } }; ytcenter.player.config = {}; ytcenter.player.cpn = ytcenter.utils.crypt(); ytcenter.player.getVideoDataRequest = function(){ /* Making sure that the require configuration is available */ if (uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG) ytcenter.player.config = uw.yt.config_.PLAYER_CONFIG; if (!ytcenter.player.config || !ytcenter.player.config.args) ytcenter.player.config = ytcenter.player.getRawPlayerConfig(); var emvid = loc.pathname.match(/\/embed\/([0-9a-zA-Z_-]+)/); if (emvid && emvid.length > 1 && emvid[1]) emvid = emvid[1]; /* Creating URL */ var a = { html5: (ytcenter.player.config && ytcenter.player.config.html5 ? "1" : "0"), video_id: ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.video_id || emvid, cpn: ytcenter.player.cpn, eurl: loc.href, ps: null, el: "embedded", hl: (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.hl ? ytcenter.player.config.args.hl : null), sts: 15973, c: "web", cver: (ytcenter.player.config.html5 ? "html5" : "flash") }, b = [], k; if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.list) { a.list = ytcenter.player.config.args.list; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.cr) { a.cr = ytcenter.player.config.args.cr; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.access_token) { a.access_token = ytcenter.player.config.args.access_token; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.adformat) { a.adformat = ytcenter.player.config.args.adformat; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.iv_load_policy) { a.iv_load_policy = ytcenter.player.config.args.iv_load_policy; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.autoplay) { a.autoplay = ytcenter.player.config.args.autoplay; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.mdx) { a.mdx = ytcenter.player.config.args.mdx; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.utpsa) { a.utpsa = ytcenter.player.config.args.utpsa; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.is_fling) { a.is_fling = ytcenter.player.config.args.is_fling; } if (window.clientWidth) { a.width = window.clientWidth; } if (window.clientHeight) { a.width = window.clientHeight; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.ypc_preview) { a.ypc_preview = ytcenter.player.config.args.ypc_preview; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.splay) { a.splay = ytcenter.player.config.args.splay; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.content_v) { a.content_v = ytcenter.player.config.args.content_v; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.livemonitor) { a.livemonitor = ytcenter.player.config.args.livemonitor; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.authuser) { a.authuser = ytcenter.player.config.args.authuser; } if (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.pageid) { a.pageid = ytcenter.player.config.args.pageid; } for (k in a) { if (a.hasOwnProperty(k)) { if (a[k] !== null) { b.push(encodeURIComponent(k) + "=" + encodeURIComponent(a[k])); } } } return ytcenter.utils.getLocationOrigin() + "/get_video_info?" + b.join("&"); }; ytcenter.player.isLiveStream = function(){ return (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.live_playback === 1); }; ytcenter.player.isOnDemandStream = function(){ return (ytcenter.player.config && ytcenter.player.config.args && ytcenter.player.config.args.ypc_module && ytcenter.player.config.args.ypc_vid); }; ytcenter.player.getRawPlayerConfig = function(){ function loadMethod1() { try { var a = document.body.innerHTML; a = a.split("<script>var ytplayer = ytplayer || {};ytplayer.config = {"); if (!a || !a[1]) return null; a = a[1]; a = a.split("};"); if (!a || !a[0]) return null; a = a[0]; a = JSON.parse("{" + a + "}"); return a; } catch (e) { con.error(e); return null; } } function loadMethod2() { var a; try { a = document.body.innerHTML; a = a.split("'PLAYER_CONFIG': "); if (!a || !a[1]) return null; a = a[1]; a = a.split(");"); if (!a || !a[0]) return null; a = a[0]; a = JSON.parse(a); return a; } catch (e) { con.error(e, a); return null; } } function loadMethod3() { var a; try { a = document.body.innerHTML; a = a.split("var videoPlayer = new yt.player.Application('p', "); if (!a || !a[1]) return null; a = a[1]; a = a.split(");"); if (!a || !a[0]) return null; a = a[0]; a = JSON.parse(a); return a; } catch (e) { con.error(e, a); return null; } } function loadMethod4() { var a; try { a = document.body.innerHTML; a = a.split("flashvars=\""); if (!a || !a[1]) return null; a = a[1]; a = a.split("\" "); if (!a || !a[0]) return null; a = a[0].replace(/&/g, "&"); a = {args: ytcenter.utils.urlComponentToObject(a)}; return a; } catch (e) { con.error(e, a); return null; } } var _a = null, page = ytcenter.getPage(); if (!_a && ytcenter.feather && page === "watch") _a = loadMethod3(); if (!_a && ytcenter.feather && page === "watch") _a = loadMethod4(); if (!_a && uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG) _a = uw.yt.config_.PLAYER_CONFIG; if (!_a && document && document.body && document.body.innerHTML && document.body.innerHTML.indexOf("<script>var ytplayer = ytplayer || {};ytplayer.config = ") !== -1) _a = loadMethod1(); if (!_a && document && document.body && document.body.innerHTML && document.body.innerHTML.indexOf("'PLAYER_CONFIG': ") !== -1) _a = loadMethod2(); if (_a) return _a; return {}; }; ytcenter.player.parseRVS = function(rvs){ var a = [], b = rvs.split(","), c, d, e, i, j; for (i = 0; i < b.length; i++) { c = {}; d = b[i].split("&"); for (j = 0; j < d.length; j++) { e = d[j].split("="); c[unescape(e[0])] = unescape(e[1]); } a.push(c); } return a; }; ytcenter.player.stringifyRVS = function(rvs){ var sb = "", i, key, j; for (i = 0; i < rvs.length; i++) { if (i > 0) sb += ","; j = 0; for (key in rvs[i]) { if (rvs[i].hasOwnProperty(key)) { if (j > 0) sb += "&"; sb += escape(key) + "=" + escape(rvs[i][key]); j++; } } } return sb; }; ytcenter.player.shortcuts = function(){ con.log("Adding player shortcuts to document"); ytcenter.utils.addEventListener(document, "keydown", function(e){ e = e || window.event; if (ytcenter.settings.enableYouTubeShortcuts && ytcenter.settings.enableShortcuts && ytcenter.getPage() === "watch" && !e.altKey && !e.ctrlKey && !e.metaKey && !e.shiftKey) { if (document.activeElement.tagName.toLowerCase() === "input" || document.activeElement.tagName.toLowerCase() === "textarea" || document.activeElement.tagName.toLowerCase() === "object" || document.activeElement.tagName.toLowerCase() === "embed" || document.activeElement.tagName.toLowerCase() === "button") return; if (document.activeElement.id === "movie_player" && ytcenter.utils.hasClass(document.activeElement, "html5-video-player")) return; if (ytcenter.utils.isParent(document.getElementById("movie_player"), document.activeElement)) return; var player = ytcenter.player.getAPI(); switch (e.keyCode) { case 32: // Space if (player.getPlayerState() == 1) { player.pauseVideo(); } else { player.playVideo(); } break; case 37: // Left Arrow player.seekTo(player.getCurrentTime()-5, true); break; case 39: // Right Arrow player.seekTo(player.getCurrentTime()+5, true); break; case 35: // End player.seekTo(player.getDuration(), true); break; case 36: // Home player.seekTo(0, true); break; case 48: // 0 player.seekTo(0, true); break; case 49: // 1 player.seekTo(0.1*player.getDuration(), true); break; case 50: // 2 player.seekTo(0.2*player.getDuration(), true); break; case 51: // 3 player.seekTo(0.3*player.getDuration(), true); break; case 52: // 4 player.seekTo(0.4*player.getDuration(), true); break; case 53: // 5 player.seekTo(0.5*player.getDuration(), true); break; case 54: // 6 player.seekTo(0.6*player.getDuration(), true); break; case 55: // 7 player.seekTo(0.7*player.getDuration(), true); break; case 56: // 8 player.seekTo(0.8*player.getDuration(), true); break; case 57: // 9 player.seekTo(0.9*player.getDuration(), true); break; default: return; } e.preventDefault(); } }, false); }; ytcenter.player.config = ytcenter.player.config || {}; // Never set this variable directly! ytcenter.player.setConfig = function(config){ ytcenter.player.config = config; }; ytcenter.player.updateConfig = function(page, config){ if (!config || !config.args) return; var api = ytcenter.player.getAPI(); con.log("[Config Update] Updating as page " + page); if (page === "watch") { ytcenter.effects.playerGlow.update(); uw.setTimeout(ytcenter.effects.playerGlow.update, 1000); // Make sure that the player glow got the state update ytcenter.player.updateResize(); if (ytcenter.settings.enableAutoVideoQuality) { ytcenter.player.setQuality(ytcenter.player.getQuality(ytcenter.settings.autoVideoQuality, ytcenter.video.streams, (config.args.dash === "1" && config.args.adaptive_fmts ? true : false))); } if (api.getVolume && api.getVolume() !== ytcenter.settings.volume && ytcenter.settings.enableVolume) { if (ytcenter.settings.volume < 0) { ytcenter.settings.volume = 0; } else if (ytcenter.settings.volume > 100) { ytcenter.settings.volume = 100; } api.setVolume(ytcenter.settings.volume); } if (ytcenter.settings.mute && api.isMuted && !api.isMuted()) { api.mute(); } else if (!ytcenter.settings.mute && api.isMuted && api.isMuted()) { api.unMute(); } ytcenter.playlist = false; try { if (document.getElementById("watch7-playlist-data") || loc.search.indexOf("list=") !== -1) { ytcenter.playlist = true; } } catch (e) { con.error(e); } // Prevent Auto Play/Buffering if (document && document.hasFocus && typeof document.hasFocus === "function" && !document.hasFocus() && ((!ytcenter.playlist && (ytcenter.settings.preventTabAutoBuffer || ytcenter.settings.preventTabAutoPlay)) || (ytcenter.playlist && (ytcenter.settings.preventTabPlaylistAutoBuffer || ytcenter.settings.preventTabPlaylistAutoPlay)))) { if (ytcenter.playlist) { if (ytcenter.settings.preventTabPlaylistAutoBuffer) { if (ytcenter.html5) { ytcenter.player.setPlaybackState(0); } } else if (ytcenter.settings.preventTabPlaylistAutoPlay) { ytcenter.player.setPlaybackState(2); } } else { if (ytcenter.settings.preventTabAutoBuffer) { if (ytcenter.html5) { ytcenter.player.setPlaybackState(0); } } else if (ytcenter.settings.preventTabAutoPlay) { ytcenter.player.setPlaybackState(2); } } } else { if (ytcenter.playlist) { if (ytcenter.settings.preventPlaylistAutoBuffer) { if (ytcenter.html5) { ytcenter.player.setPlaybackState(0); } } else if (ytcenter.settings.preventPlaylistAutoPlay) { ytcenter.player.setPlaybackState(2); } } else { if (ytcenter.settings.preventAutoBuffer) { if (ytcenter.html5) { ytcenter.player.setPlaybackState(0); } } else if (ytcenter.settings.preventAutoPlay) { ytcenter.player.setPlaybackState(2); } } } } else if (page === "channel") { if (ytcenter.settings.channel_enableVolume) { if (ytcenter.settings.channel_volume < 0) { ytcenter.settings.channel_volume = 0; } else if (ytcenter.settings.channel_volume > 100) { ytcenter.settings.channel_volume = 100; } if (api.setVolume) { api.setVolume(ytcenter.settings.channel_volume); } } if (ytcenter.settings.channel_mute && api.mute) { api.mute(); } else if (!ytcenter.settings.channel_mute && api.unMute) { api.unMute(); } if (ytcenter.settings.channel_preventAutoBuffer) { ytcenter.player.setPlaybackState(0); } else if (ytcenter.settings.channel_preventAutoPlay) { ytcenter.player.setPlaybackState(2); } else { ytcenter.player.setPlaybackState(1); } if (api.getPlaybackQuality() !== config.args.vq) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.channel_autoVideoQuality; } con.log("[Player Update] Quality => " + config.args.vq); ytcenter.player.setQuality(config.args.vq); } } else if (page === "embed") { if (ytcenter.settings.embed_enableVolume) { if (ytcenter.settings.embed_volume < 0) { ytcenter.settings.embed_volume = 0; } else if (ytcenter.settings.embed_volume > 100) { ytcenter.settings.embed_volume = 100; } if (api.setVolume) { api.setVolume(ytcenter.settings.embed_volume); } } try { if (ytcenter.settings.embed_mute) { api.mute(); } else if (!ytcenter.settings.embed_mute) { api.unMute(); } } catch (e) { con.error(e); } if (!ytcenter.settings.embed_defaultAutoplay) { if (ytcenter.settings.embed_preventAutoBuffer) { var played = false; ytcenter.player.listeners.addEventListener("onStateChange", function(s){ if (s !== 1 || played) return; played = true; if (api.getPlaybackQuality() !== ytcenter.settings.embed_autoVideoQuality) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.embed_autoVideoQuality; } con.log("Setting playback quality from " + api.getPlaybackQuality() + " to " + ytcenter.settings.embed_autoVideoQuality); ytcenter.player.setPlaybackQuality(config.args.vq); } }); } else if (ytcenter.settings.embed_preventAutoPlay) { api.playVideo(); api.pauseVideo(); uw.setTimeout(function(){ if (api.getPlaybackQuality() !== ytcenter.settings.embed_autoVideoQuality) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.embed_autoVideoQuality; } con.log("Setting playback quality from " + api.getPlaybackQuality() + " to " + ytcenter.settings.embed_autoVideoQuality); ytcenter.player.setPlaybackQuality(config.args.vq); } }, 600); } else { ytcenter.player.listeners.addEventListener("onStateChange", function(s){ if (s !== 1 || played) return; played = true; if (api.getPlaybackQuality() !== ytcenter.settings.embed_autoVideoQuality) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.embed_autoVideoQuality; } con.log("Setting playback quality from " + api.getPlaybackQuality() + " to " + ytcenter.settings.embed_autoVideoQuality); ytcenter.player.setPlaybackQuality(config.args.vq); } }); api.playVideo(); } } else if (loc.search.indexOf("ytcenter-autoplay=1") !== -1) { ytcenter.player.listeners.addEventListener("onStateChange", function(s){ if (s !== 1 || played) return; played = true; if (api.getPlaybackQuality() !== ytcenter.settings.embed_autoVideoQuality) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.embed_autoVideoQuality; } con.log("Setting playback quality from " + api.getPlaybackQuality() + " to " + ytcenter.settings.embed_autoVideoQuality); ytcenter.player.setPlaybackQuality(config.args.vq); } }); api.playVideo(); } if (api.getPlaybackQuality() !== ytcenter.settings.embed_autoVideoQuality) { if (config.args.vq === "auto") { config.args.vq = ytcenter.settings.embed_autoVideoQuality; } con.log("Setting playback quality from " + api.getPlaybackQuality() + " to " + ytcenter.settings.embed_autoVideoQuality); ytcenter.player.setPlaybackQuality(config.args.vq); } } }; ytcenter.player.calculateRatio = function(dash, predefinedAspect){ var i, a; /*predefinedAspect = predefinedAspect || ytcenter.settings['aspectValue']; // Checking if the ratio is predefined if (predefinedAspect && predefinedAspect.indexOf("=") !== -1) { a = predefinedAspect.split("=")[1]; if (a.indexOf(":") !== -1) { a = a.split(":"); a = parseInt(a[0])/parseInt(a[1]); if (!isNaN(a)) return a; } }*/ predefinedAspect = predefinedAspect || ytcenter.settings['playerSizeAspect']; // Checking if the ratio is predefined if (predefinedAspect && predefinedAspect !== "default") { a = predefinedAspect; if (a.indexOf(":") !== -1) { a = a.split(":"); a = parseInt(a[0])/parseInt(a[1]); if (!isNaN(a)) return a; } } // Calculating the aspect ratio... if (dash) { for (i = 0; i < ytcenter.video.streams.length; i++) { if (ytcenter.video.streams[i].size) { a = ytcenter.video.streams[i].size.split("x"); break; } } } else { for (i = 0; i < ytcenter.video.streams.length; i++) { if (ytcenter.video.streams[i].dimension) { a = ytcenter.video.streams[i].dimension.split("x"); break; } } } if (a) { a = parseInt(a[0])/parseInt(a[1]); if (isNaN(a)) return 16/9; return a; } else { return 16/9; } }; ytcenter.player.experiments = (function(){ function add(exp, config) { var cfg = getConfig(config); if (!has(exp, config)) { cfg.args.fexp += "," + exp; } } function remove(exp, config) { var cfg = getConfig(config); if (cfg && cfg.args && cfg.args.fexp) { var e = cfg.args.fexp.split(","), i, a = []; for (i = 0; i < e.length; i++) { if (exp !== e[i]) { a.push(e[i]); } } cfg.args.fexp = a.join(","); } } function has(exp, config) { var cfg = getConfig(config); if (cfg && cfg.args && typeof cfg.fexp === "string") { var e = cfg.args.fexp.split(","), i, a = []; for (i = 0; i < e.length; i++) { if (exp === e[i]) { return true; } } } return false; } function clear(config) { var cfg = getConfig(config); if (cfg && cfg.args) { cfg.args.fexp = ""; } } function getConfig(config) { return config || ytcenter.player.config.args; } return { add: add, remove: remove, has: has, clear: clear }; })(); ytcenter.player.modifyConfig = function(page, config){ if (page !== "watch" && page !== "embed" && page !== "channel") return config; if (loc.href.indexOf(".youtube.com/embed/") !== -1 && !ytcenter.settings.embed_enabled) return config; if (!config) config = {}; if (!config.args) config.args = {}; con.log("[Player modifyConfig] => " + page); if (document.getElementById("upsell-video")) { var swf_config = JSON.parse(document.getElementById("upsell-video").getAttribute("data-swf-config").replace(/&/g, "&").replace(/"/g, "\"")); config = swf_config; } if (loc.hash.indexOf("t=") !== -1) { var hashObject = ytcenter.utils.urlComponentToObject(loc.hash.substring(1)), value = null, matches = null, i; if (typeof hashObject.t !== "undefined") { if (matches = hashObject.t.match(/^([0-9]+m)|([0-9]+s)$/g)) { value = 0; for (i = 0; i < matches.length; i++) { if (matches[i].indexOf("s") === matches[i].length - 1) { value += parseInt(matches[i], 10); } else if (matches[i].indexOf("m") === matches[i].length - 1) { value += parseInt(matches[i], 10) * 60; } else if (matches[i].indexOf("h") === matches[i].length - 1) { value += parseInt(matches[i], 10) * 60 * 60; } } } else { value = parseInt(hashObject.t, 10); } } if (value !== null) { config.args.start = value; } } if (config && config.args && ((config.args.url_encoded_fmt_stream_map && config.args.fmt_list) || config.args.adaptive_fmts)) { var streams = ytcenter.parseStreams(config.args); ytcenter.video.streams = streams; try { if (ytcenter.video && ytcenter.video.streams && ytcenter.video.streams[0] && ytcenter.video.streams[0].s) { ytcenter.utils.updateSignatureDecipher(); // Only Updating the signature decoder when it's needed! } } catch (e) { con.error("[updateSignatureDecipher] Error,", e); } ytcenter.unsafe.video = {}; ytcenter.unsafe.video.streams = ytcenter.video.streams; ytcenter.video.id = config.args.video_id; ytcenter.video.title = config.args.title; } config.args.ytcenter = 1; config.args.enablejsapi = 1; config.args.jsapicallback = "ytcenter.player.onReady"; if (ytcenter.getPage() === "watch") { ytcenter.descriptionTags.addSection("DESCRIPTIONTAG_KEYWORDS", config.args.keywords.split(",")); ytcenter.descriptionTags.addSection("DESCRIPTIONTAG_FPS", ytcenter.player.getFPSArray(ytcenter.video.streams)); if (ytcenter.settings.bufferEnabled) { config.args.tsp_buffer = ytcenter.settings.bufferSize; } if (ytcenter.settings.enable_custom_fexp) { config.args.fexp = ytcenter.settings.custom_fexp; } else { // Why did I not think about looking at the YouTube experiments before??? The most simple solution to the issue with the annotations' size and position for the HTML5 player. //ytcenter.player.experiments.clear(config); ytcenter.player.experiments.remove("931983", config); // YouTube will probably change this in a few months.. again. ytcenter.player.experiments.remove("931972", config); } if (!config.args.video_id) { config.args.video_id = ytcenter.utils.query("v"); } if (ytcenter.settings.enableYouTubeShortcuts) { config.args.disablekb = 0; } else { config.args.disablekb = 1; } if ((ytcenter.settings.forcePlayerType === "flash" || ytcenter.settings.forcePlayerType === "aggressive_flash") && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = false; ytcenter.player.setPlayerType("flash"); } else if (ytcenter.settings.forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; config.args.allow_html5_ads = 1; config.args.html5_sdk_version = "3.1"; ytcenter.player.setPlayerType("html5"); } } else if (ytcenter.getPage() === "embed") { if (ytcenter.settings.embedBufferEnabled) { config.args.tsp_buffer = ytcenter.settings.embedBufferSize; } if ((ytcenter.settings.embed_forcePlayerType === "flash" || ytcenter.settings.embed_forcePlayerType === "aggressive_flash") && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = false; config.args.html5_sdk_version = "0"; ytcenter.player.setPlayerType("flash"); } else if (ytcenter.settings.embed_forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; config.args.allow_html5_ads = 1; config.args.html5_sdk_version = "3.1"; ytcenter.player.setPlayerType("html5"); } } else if (ytcenter.getPage() === "channel") { if (ytcenter.settings.channelBufferEnabled) { config.args.tsp_buffer = ytcenter.settings.channelBufferSize; } if ((ytcenter.settings.channel_forcePlayerType === "flash" || ytcenter.settings.channel_forcePlayerType === "aggressive_flash") && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = false; config.args.html5_sdk_version = "0"; ytcenter.player.setPlayerType("flash"); } else if (ytcenter.settings.channel_forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; config.args.allow_html5_ads = 1; config.args.html5_sdk_version = "3.1"; ytcenter.player.setPlayerType("html5"); } } if (config.html5) ytcenter.html5 = true; else ytcenter.html5 = false; con.log("[Player Type] " + (ytcenter.html5 ? "HTML5" : "Flash")); if (ytcenter.settings.removeRelatedVideosEndscreen) { delete config.args.endscreen_module; delete config.args.rvs; } if (ytcenter.settings.enableResize) config.args.player_wide = ytcenter.settings.player_wide ? "1" : "0"; if (page === "watch") { var ___callback = function(response){ try { var txt = response.responseText; if (txt) { txt = txt.split("<published>"); if (txt && txt.length > 1) { txt = txt[1].split("</published>"); if (txt && txt.length > 0) { txt = txt[0]; ytcenter.video.published = new Date(txt); } } } } catch (e) { con.error(e); } //ytcenter.events.performEvent("ui-refresh"); }; if (config.args.video_id) { ytcenter.utils.xhr({ method: "GET", url: "https://gdata.youtube.com/feeds/api/videos/" + config.args.video_id + "?v=2", headers: { "Content-Type": "text/plain" }, onerror: ___callback, onload: ___callback }); } if (ytcenter.settings.dashPlayback && config.args.adaptive_fmts) { config.args.dash = "1"; } else { config.args.dash = "0"; config.args.dashmpd = ""; } if (ytcenter.settings.enableAutoVideoQuality) { // This does not work with the HTML5 player anymore. config.args.vq = ytcenter.player.getQuality(ytcenter.settings.autoVideoQuality, streams, (config.args.dash === "1" && config.args.adaptive_fmts ? true : false)); config.args.suggestedQuality = config.args.vq; var vqDim = ytcenter.player.getQualityDimension(config.args.vq); if (vqDim) config.args.video_container_override = vqDim; } if (config.args.dash === "1" && config.args.adaptive_fmts) { ytcenter.player.setRatio(ytcenter.player.calculateRatio(true)); } else { ytcenter.player.setRatio(ytcenter.player.calculateRatio(false)); } if (ytcenter.settings.removeAdvertisements) { config = ytcenter.site.removeAdvertisement(config); } if (ytcenter.settings.removeBrandingWatermark) { delete config.args.watermark; delete config.args.interstitial; } if (ytcenter.settings.aspectValue !== "none" && ytcenter.settings.aspectValue !== "default" && ytcenter.settings.aspectValue.indexOf("yt:") === 0) { con.log("Chaning aspect to " + ytcenter.settings.aspectValue); config.args.keywords = ytcenter.settings.aspectValue; } else if (ytcenter.settings.aspectValue !== "default") { con.log("Chaning aspect to none"); config.args.keywords = ""; } else { con.log("Keeping the aspect"); } if ((ytcenter.settings.forcePlayerType === "flash" || ytcenter.settings.forcePlayerType === "aggressive_flash")) { config.html5 = false; } else if (ytcenter.settings.forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; } if (ytcenter.settings.enableAnnotations) { config.args.iv_load_policy = 1; } else { config.args.iv_load_policy = 3; } if (typeof ytcenter.settings.autohide != "undefined" && ytcenter.settings.autohide !== "-1") { config.args.autohide = ytcenter.settings.autohide; } if (ytcenter.settings.bgcolor === "none") { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", "#000000"); } else if (ytcenter.settings.bgcolor !== "default" && ytcenter.settings.bgcolor.indexOf("#") === 0) { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", ytcenter.settings.bgcolor); } ytcenter.playlist = false; try { if (document.getElementById("watch7-playlist-data") || loc.search.indexOf("list=") !== -1) { ytcenter.playlist = true; } } catch (e) { con.error(e); } con.log("[Playlist] " + (ytcenter.playlist ? "Enabled" : "Disabled")); if (document && document.hasFocus && typeof document.hasFocus === "function" && !document.hasFocus() && ((!ytcenter.playlist && (ytcenter.settings.preventTabAutoBuffer || ytcenter.settings.preventTabAutoPlay)) || (ytcenter.playlist && (ytcenter.settings.preventTabPlaylistAutoBuffer || ytcenter.settings.preventTabPlaylistAutoPlay)))) { config.args.autoplay = "0"; } else { if (ytcenter.playlist) { if (ytcenter.settings.preventPlaylistAutoBuffer || ytcenter.settings.preventPlaylistAutoPlay) { config.args.autoplay = "0"; } else { config.args.autoplay = "1"; } } else { if (ytcenter.settings.preventAutoBuffer || ytcenter.settings.preventAutoPlay) { config.args.autoplay = "0"; } else { config.args.autoplay = "1"; } } } config.args.theme = ytcenter.settings.playerTheme; config.args.color = ytcenter.settings.playerColor; ytcenter.player.setTheme(ytcenter.settings.playerTheme); ytcenter.player.setProgressColor(ytcenter.settings.playerColor); ytcenter.player.setAutoHide(ytcenter.settings.autohide); if (config.args.rvs) { var rvs = ytcenter.player.parseRVS(config.args.rvs), i; if (ytcenter.settings.enableEndscreenAutoplay && ytcenter.settings.removeRelatedVideosEndscreen) { if (rvs.length > 0) { rvs[0].endscreen_autoplay = 1; for (i = 1; i < rvs.length; i++) { if (typeof rvs[i].endscreen_autoplay !== "undefined") { delete rvs[i].endscreen_autoplay; } } } config.args.rvs = ytcenter.player.stringifyRVS(rvs); } else { if (rvs.length > 0) { for (i = 0; i < rvs.length; i++) { if (typeof rvs[i].endscreen_autoplay !== "undefined") { delete rvs[i].endscreen_autoplay; } } } config.args.rvs = ytcenter.player.stringifyRVS(rvs); } } } else if (page === "embed") { if (ytcenter.settings.embed_forcePlayerType === "flash" || ytcenter.settings.embed_forcePlayerType === "aggressive_flash") { config.html5 = false; } else if (ytcenter.settings.embed_forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; } if (ytcenter.settings.removeAdvertisements) { config = ytcenter.site.removeAdvertisement(config); } if (ytcenter.settings.embed_dashPlayback) { config.args.dash = "1"; } else { config.args.dash = "0"; config.args.dashmpd = ""; } if (ytcenter.settings.embed_enableAutoVideoQuality) { var vq = ytcenter.player.getQuality(ytcenter.settings.embed_autoVideoQuality, streams, (config.args.dash === "1" && config.args.adaptive_fmts ? true : false)); config.args.vq = vq; config.args.suggestedQuality = vq; var vqDim = ytcenter.player.getQualityDimension(vq); if (vqDim) config.args.video_container_override = vqDim; } if (!ytcenter.settings.embed_enableAnnotations) { config.args.iv_load_policy = 3; } else { config.args.iv_load_policy = 1; } if (typeof ytcenter.settings.embed_autohide !== "undefined" && ytcenter.settings.embed_autohide !== "-1") { config.args.autohide = ytcenter.settings.embed_autohide; } if (!ytcenter.settings.embed_defaultAutoplay) config.args.autoplay = "0"; config.args.theme = ytcenter.settings.embed_playerTheme; config.args.color = ytcenter.settings.embed_playerColor; ytcenter.player.setTheme(ytcenter.settings.playerTheme); ytcenter.player.setProgressColor(ytcenter.settings.playerColor); ytcenter.player.setAutoHide(ytcenter.settings.embed_autohide); if (ytcenter.settings.embed_bgcolor === "none") { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", ""); } else if (ytcenter.settings.embed_bgcolor !== "default" && ytcenter.settings.embed_bgcolor.indexOf("#") === 0) { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", ytcenter.settings.embed_bgcolor); } } else if (page === "channel") { if (ytcenter.settings.channel_forcePlayerType === "flash" || ytcenter.settings.channel_forcePlayerType === "aggressive_flash") { config.html5 = false; } else if (ytcenter.settings.channel_forcePlayerType === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()) { config.html5 = true; delete config.args.ad3_module; } if (ytcenter.settings.channel_dashPlayback) { config.args.dash = "1"; } else { config.args.dash = "0"; config.args.dashmpd = ""; } if (ytcenter.settings.channel_enableAutoVideoQuality) { var vq = ytcenter.player.getQuality(ytcenter.settings.channel_autoVideoQuality, streams, (config.args.dash === "1" && config.args.adaptive_fmts ? true : false)); config.args.vq = vq; config.args.suggestedQuality = vq; var vqDim = ytcenter.player.getQualityDimension(vq); if (vqDim) config.args.video_container_override = vqDim; } if (ytcenter.settings.removeAdvertisements) { config = ytcenter.site.removeAdvertisement(config); } if (!ytcenter.settings.channel_enableAnnotations) { config.args.iv_load_policy = 3; } else { config.args.iv_load_policy = 1; } if (typeof ytcenter.settings.channel_autohide != "undefined" && ytcenter.settings.channel_autohide !== "-1") { config.args.autohide = ytcenter.settings.channel_autohide; } /*if (ytcenter.settings.embed_defaultAutoplay) { if (loc.search.indexOf("ytcenter-autoplay=1") !== -1) { config.args.autoplay = "1"; } else { config.args.autoplay = "0"; } } else { config.args.autoplay = (ytcenter.settings.embed_preventAutoBuffer ? "0" : "1"); }*/ config.args.autoplay = "0"; config.args.theme = ytcenter.settings.channel_playerTheme; config.args.color = ytcenter.settings.channel_playerColor; ytcenter.player.setTheme(ytcenter.settings.playerTheme); ytcenter.player.setProgressColor(ytcenter.settings.playerColor); ytcenter.player.setAutoHide(ytcenter.settings.channel_autohide); config.args.enablejsapi = "1"; if (ytcenter.settings.channel_bgcolor === "none") { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", "#000000"); } else if (ytcenter.settings.channel_bgcolor !== "default" && ytcenter.settings.channel_bgcolor.indexOf("#") === 0) { config.args.keywords = ytcenter.utils.setKeyword(config.args.keywords, "yt:bgcolor", ytcenter.settings.channel_bgcolor); } if (document.getElementById("upsell-video")) { document.getElementById("upsell-video").setAttribute("data-swf-config", JSON.stringify(config).replace(/&/g, "&").replace(/"/g, """)); } } return config; }; ytcenter.player.getAPI = function(){ if (loc.pathname.indexOf("/embed/") === 0 && uw.yt && uw.yt.player && uw.yt.player.getPlayerByElement) { return uw.yt.player.getPlayerByElement(document.getElementById("player")); } if (ytcenter.player.__getAPI && ytcenter.player.__getAPI.addEventListener) { return ytcenter.player.__getAPI; // Note: Never use yt.player.embed function to fetch the API. Just catch the API through onYouTubePlayerReady. } else { var player = document.getElementById("movie_player"); var api = ytcenter.player.__getAPI || { }; if (player && player.getApiInterface) { var apiInterface = player.getApiInterface(); for (var i = 0, len = apiInterface.length; i < len; i++) { api[apiInterface[i]] = ytcenter.utils.funcBind(player, player[apiInterface[i]]); } } return api; } }; ytcenter.player.setPlayerWide = function(center){ ytcenter.settings.player_wide = (center ? true : false); ytcenter.utils.setCookie("wide", (center ? "1" : "0"), null, "/", 3600*60*24*30); ytcenter.saveSettings(); }; ytcenter.player.toggleLights = function(){ if (ytcenter.player.isLightOff) { ytcenter.player.turnLightOn(); } else { ytcenter.player.turnLightOff(); } }; ytcenter.player.turnLightOn = function(){}; ytcenter.player.isLightOff = false; ytcenter.player.turnLightOff = (function(){ var lightElement; return function(){ if (!lightElement) { lightElement = document.createElement("div"); lightElement.className = "ytcenter-lights-off-overlay hid"; lightElement.style.background = ytcenter.settings.lightbulbBackgroundColor; lightElement.style.opacity = ytcenter.settings.lightbulbBackgroundOpaque/100; lightElement.style.filter = "alpha(opacity=" + ytcenter.settings.lightbulbBackgroundOpaque + ")"; ytcenter.utils.addEventListener(lightElement, "click", function(){ if (!ytcenter.settings["lightbulbClickThrough"]) ytcenter.player.turnLightOn(); }, false); ytcenter.player.turnLightOn = function(){ ytcenter.utils.addClass(lightElement, "hid"); ytcenter.utils.removeClass(document.body, "ytcenter-lights-off"); ytcenter.player.isLightOff = false; ytcenter.effects.playerGlow.update(); }; document.body.appendChild(lightElement); } // Updating background color and opacity. lightElement.style.background = ytcenter.settings.lightbulbBackgroundColor; lightElement.style.opacity = ytcenter.settings.lightbulbBackgroundOpaque/100; lightElement.style.filter = "alpha(opacity=" + ytcenter.settings.lightbulbBackgroundOpaque + ")"; ytcenter.utils.addClass(document.body, "ytcenter-lights-off"); ytcenter.utils.removeClass(lightElement, "hid"); ytcenter.player.isLightOff = true; ytcenter.effects.playerGlow.update(); }; })(); ytcenter.player.checkHTML5Support = function(){ var v = document.createElement("video"); if (v && !v.canPlayType) { return false; } var mp4 = v.canPlayType('video/mp4; codecs="avc1.42001E, mp4a.40.2"'); var webm = v.canPlayType('video/webm; codecs="vp8.0, vorbis"'); var found = false; for (var i = 0; i < ytcenter.video.streams.length; i++) { if (mp4 && ytcenter.video.streams[i].type.indexOf("video/mp4;") === 0) { found = true; break; } else if (webm && ytcenter.video.streams[i].type.indexOf("video/webm;") === 0) { found = true; break; } } return found; }; ytcenter.player.setYTConfig = function(config){ if (uw.yt && uw.yt.setConfig) uw.yt.setConfig(config); }; ytcenter.player.getYTConfig = function(config){ uw.yt.getConfig(config); }; ytcenter.player.getConfig = function(){ return ytcenter.player.config; }; ytcenter.player.getPlayerId = (function(){ function verify() { var n = -1; ytcenter.utils.each(uw, function(key, value){ if (key.indexOf("ytPlayer") !== 0) return; // || key.indexOf(("player" + i), key.length - ("player" + i).length) !== -1 var __n = key.substr(key.lastIndexOf("player") + "player".length); if (!/^\d+$/.test(__n)) return; var _n = parseInt(__n); if (_n > n) n = _n; }); if (n > -1) verified = n; } var verified = 1; return function(){ verify(); return "player" + verified; }; })(); ytcenter.player.getReference = (function(){ return function(playerid){ ytcenter.player.reference = ytcenter.player.reference || {}; if (playerid) { ytcenter.player.reference.playerId = playerid; } //ytcenter.player.reference.api = ytcenter.player.getAPI(); if (ytcenter.page === "embed") { ytcenter.referenceMethod = "embed"; if (document.getElementById("video-player")) { ytcenter.player.reference.target = document.getElementById("video-player"); } else if (!ytcenter.html5 && document.getElementsByTagName("embed").length > 0) { ytcenter.player.reference.target = document.getElementsByTagName("embed")[0]; } ytcenter.player.reference.config = ytcenter.player.getConfig(); } else if (ytcenter.page === "channel") { ytcenter.referenceMethod = "channel"; if (document.getElementById("movie_player")) { ytcenter.player.reference.target = document.getElementById("movie_player"); } else if (!ytcenter.html5 && document.getElementsByTagName("embed").length > 0) { ytcenter.player.reference.target = document.getElementsByTagName("embed")[0]; } ytcenter.player.reference.config = ytcenter.player.getConfig(); } else { if (uw && uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_REFERENCE) { ytcenter.referenceMethod = "PLAYER REFERENCE"; ytcenter.player.reference.api = uw.yt.config_.PLAYER_REFERENCE; ytcenter.player.reference.target = document.getElementById("movie_player") || document.getElementById("embed")[0]; ytcenter.player.reference.onReadyCalled = true; } else if (document.getElementById("movie_player") || document.getElementsByTagName("embed").length > 0) { ytcenter.referenceMethod = "binding"; ytcenter.player.reference.target = document.getElementById("movie_player") || document.getElementById("embed")[0]; ytcenter.player.reference.onReadyCalled = true; } ytcenter.player.reference.html5 = ytcenter.html5; } return ytcenter.player.reference; }; })(); ytcenter.player.listeners = (function(){ // Get the YouTube listener for the passed event. function getYouTubeListener(event) { var ytEvent = "ytPlayer" + event + "player" + getPlayerId(); return ytListeners[ytEvent]; } // The latest player id registered in the global window. function getNewestPlayerId() { var id = 1; var uid = null; var i = null; ytcenter.utils.each(uw, function(key, value){ if (key.indexOf("ytPlayer") !== -1) { var match = key.match(/player([0-9]+)$/); var uidMatch = key.match(/player_uid_([0-9]+)_([0-9]+)$/); if (uidMatch) { uid = parseInt(uidMatch[1], 10); i = parseInt(uidMatch[2], 10); if (i > id) { id = i; } } else if (match) { i = parseInt(match[1], 10); if (i > id) { id = i; } } } }); return [uid, id]; } function ytListenerContainerSetter(event, func) { var ytEvent = "ytPlayer" + event + "player" + getPlayerId(); ytListeners[ytEvent] = func; } function ytListenerContainerGetter(event, func) { return ytcenter.utils.funcBind(null, callListener, event, 1); } /* Origin argument * If origin is equal to 0 then the origin is directly from the player (only YouTube Center's listeners get executed if override is false). * If origin is equal to 1 then the origin is from the global listeners (both YouTube's and YouTube Center's listeners get executed). */ function callListener(event, origin) { function generateThisObject() { return { getOriginalListener: ytcenter.utils.funcBind(null, getYouTubeListener, event) }; } var ytEvent = "ytPlayer" + event + "player" + getPlayerId(); var args = Array.prototype.slice.call(arguments, 2); var returnVal = null; ytcenter.player._update_onYouTubeReady = true; // The listener got called therefore the player is here. if (enabled && origin === 0 && (!events.hasOwnProperty(event) || (events.hasOwnProperty(event) && !events[event].override))) { /* Override is false and the origin is from the player; call the YouTube Center listeners */ if (events.hasOwnProperty(event)) { for (var i = 0, len = events[event].listeners.length; i < len; i++) { returnVal = events[event].listeners[i].apply(null, args); } } } else if (enabled && origin === 1) { if (events.hasOwnProperty(event) && events[event].override) { /* Override is true and the origin is from the global window; call the YouTube Center listeners */ for (var i = 0, len = events[event].listeners.length; i < len; i++) { events[event].listeners[i].apply(generateThisObject(), args); } con.log("[Player Listener] Event " + event + " was called with", args); } else if (ytListeners[ytEvent]) { if (apiNotAvailable) { /* API is not available therefore call YouTube Center listeners as YouTube listener is called */ for (var i = 0, len = events[event].listeners.length; i < len; i++) { returnVal = events[event].listeners[i].apply(null, args); } } /* Override is false and the origin is from the global window; call the YouTube listener */ returnVal = ytListeners[ytEvent].apply(uw, args); con.log("[Player Listener] Event " + event + " was called with", args); } } else if (!enabled) { /* Everything is disabled; call the YouTube listener */ returnVal = ytListeners[ytEvent].apply(uw, args); } return returnVal; } function addPlayerListener() { var api = ytcenter.player.getAPI(); var event; if (api && api.addEventListener) { apiNotAvailable = false; for (event in events) { if (events.hasOwnProperty(event)) { playerListener[event] = ytcenter.utils.funcBind(null, callListener, event, 0); api.addEventListener(event, playerListener[event]); } } } else { apiNotAvailable = true; con.error("[Player Listener] Player API is not available!"); } } function setupGlobalListeners() { if (globalListenersInitialized) return; // Make sure that this function is only called once. globalListenersInitialized = true; for (var event in events) { if (events.hasOwnProperty(event)) { var ytEvent = "ytPlayer" + event + "player" + getPlayerId(); if (uw[ytEvent]) { ytListeners[ytEvent] = uw[ytEvent]; } defineLockedProperty(uw, ytEvent, ytcenter.utils.funcBind(null, ytListenerContainerSetter, event), ytcenter.utils.funcBind(null, ytListenerContainerGetter, event) ); } } } function getPlayerId() { if (ytcenter.utils.isArray(playerId)) { return "_uid_" + playerId[0] + "_" + playerId[1]; } else { return playerId; } } function setup() { if (enabled) return; con.log("[Player Listener] Has begun the setup..."); var api = ytcenter.player.getAPI(); playerId = getNewestPlayerId(); enabled = true; // Indicate that the it's active. // Add the listeners normally to the player addPlayerListener(); // Replace the global listeners with custom listeners in case the override property is set to true setupGlobalListeners(); } function addEventListener(event, listener) { if (!events.hasOwnProperty(event)) return; removeEventListener(event, listener); // Make sure that there is only one instance of the listener registered. events[event].listeners.push(listener); } function removeEventListener(event, listener) { if (!events.hasOwnProperty(event)) return; for (var i = 0, len = events[event].listeners.length; i < len; i++) { if (events[event].listeners[i] === listener) { return events[event].listeners.splice(i, 1); } } } function setOverride(event, override) { if (!events.hasOwnProperty(event)) return; events[event].override = !!override; } function unloadPlayerListeners() { var api = ytcenter.player.getAPI(); var event; if (api && api.removeEventListener) { for (event in events) { if (events.hasOwnProperty(event)) { api.removeEventListener(event, playerListener[event]); delete playerListener[event]; } } } else { con.error("[Player Listener] Player API is not available!"); } } function unload() { unloadPlayerListeners(); enabled = false; apiNotAvailable = true; } function fireEvent(event) { var args = Array.prototype.slice.call(arguments, 1); callListener.apply(this, [event, 1].concat(args)); } var playerId = 1; var ytListeners = {}; var playerListener = {}; // Reference for unload var enabled = false; var globalListenersInitialized = false; var apiNotAvailable = true; var events = { "onApiChange": { override: false, listeners: [] }, "onCueRangeEnter": { override: false, listeners: [] }, "onCueRangeExit": { override: false, listeners: [] }, "onError": { override: false, listeners: [] }, "onNavigate": { override: false, listeners: [] }, "onPlaybackQualityChange": { override: false, listeners: [] }, "onStateChange": { override: false, listeners: [] }, "onTabOrderChange": { override: false, listeners: [] }, "onVolumeChange": { override: false, listeners: [] }, "onAdStart": { override: false, listeners: [] }, "onReady": { override: false, listeners: [] }, "RATE_SENTIMENT": { override: false, listeners: [] }, "SHARE_CLICKED": { override: false, listeners: [] }, "SIZE_CLICKED": { override: false, listeners: [] }, "WATCH_LATER": { override: false, listeners: [] }, "WATCH_LATER_VIDEO_ADDED": { override: false, listeners: [] }, "WATCH_LATER_VIDEO_REMOVED": { override: false, listeners: [] }, "SUBSCRIBE": { override: false, listeners: [] }, "UNSUBSCRIBE": { override: false, listeners: [] }, "AdvertiserVideoView": { override: false, listeners: [] }, "captionschanged": { override: false, listeners: [] }, "onRemoteReceiverSelected": { override: false, listeners: [] }, "onFullscreenChange": { override: false, listeners: [] } }; return { addEventListener: addEventListener, removeEventListener: removeEventListener, fireEvent: fireEvent, setOverride: setOverride, setup: setup, dispose: unload }; })(); ytcenter.player.setAutoHide = function(autohide){ if (!ytcenter.html5 || autohide === "-1") return; con.log("[HTML5 Player] Setting autohide to " + autohide); var target = ytcenter.player.getReference().target; if (target) { ytcenter.utils.removeClass(target, "ytcenter-autohide-both ytcenter-autohide-controlbar ytcenter-autohide-progressbar ytcenter-autohide-none autohide-controlbar autominimize-controls-aspect autohide-controls-fullscreenonly autohide-controls hide-controls-when-cued autominimize-progress-bar autominimize-progress-bar-fullscreenonly autohide-controlbar-fullscreenonly"); if (autohide === "0") { // None ytcenter.utils.addClass(target, "ytcenter-autohide-none autohide-controls-fullscreenonly autominimize-progress-bar-fullscreenonly"); } else if (autohide === "1") { // Both ytcenter.utils.addClass(target, "ytcenter-autohide-both autominimize-progress-bar autohide-controls hide-controls-when-cued"); } else if (autohide === "2") { // Progressbar ytcenter.utils.addClass(target, "ytcenter-autohide-progressbar autominimize-progress-bar autominimize-controls-aspect autohide-controls-fullscreenonly"); } else if (autohide === "3") { // Controlbar ytcenter.utils.addClass(target, "ytcenter-autohide-controlbar autohide-controlbar autohide-controls-fullscreenonly autominimize-progress-bar"); } ytcenter.events.performEvent("resize-update"); } }; ytcenter.player.setTheme = function(theme){ if (!ytcenter.html5) return; con.log("[HTML5 Player] Setting player theme to " + theme); var light = "light-theme", dark = "dark-theme", target = document.getElementById("movie_player"); if (target) { if (theme === "dark") { ytcenter.utils.removeClass(target, light); ytcenter.utils.addClass(target, dark); } else if (theme === "light") { ytcenter.utils.removeClass(target, dark); ytcenter.utils.addClass(target, light); } } }; ytcenter.player.setProgressColor = function(color){ if (!ytcenter.html5) return; con.log("[HTML5 Player] Setting player progress color to " + color); var white = "white", red = "red", els = document.getElementsByClassName("html5-progress-bar"), i; for (i = 0; i < els.length; i++) { if (color === "red") { ytcenter.utils.removeClass(els[i], white); ytcenter.utils.addClass(els[i], red); } else if (color === "white") { ytcenter.utils.removeClass(els[i], red); ytcenter.utils.addClass(els[i], white); } } ytcenter.classManagement.applyClasses(); }; ytcenter.player.aspect = function(option){ var config = ytcenter.player.getConfig(); config.args.keywords = option; con.log("Keywords changed to " + config.args.keywords); var api = ytcenter.player.getAPI(); var muted = api.isMuted(); var volume = api.getVolume(); var rate = api.getPlaybackRate(); var quality = api.getPlaybackQuality(); var time = api.getCurrentTime(); var state = api.getPlayerState(); var dur = api.getDuration(); if (state === 0) { time = dur + 60; } var __c = function(s){ if (s !== 1) return; ytcenter.player.listeners.removeEventListener("onStateChange", __c); con.log("Setting player option to last player"); if (state === -1) { api.stopVideo(); } else if (state === 2) { api.pauseVideo(); api.seekTo(time); } else { api.seekTo(time); } api.setVolume(volume); if (muted) { api.mute(muted); } api.setPlaybackRate(rate); ytcenter.player.setQuality(quality); con.log("Made a live refresh"); }; ytcenter.player.listeners.addEventListener("onStateChange", __c); api.loadVideoByPlayerVars(ytcenter.player.getConfig().args); if (config.args.dash === "1" && config.args.adaptive_fmts) { ytcenter.player.setRatio(ytcenter.player.calculateRatio(true, option)); } else { ytcenter.player.setRatio(ytcenter.player.calculateRatio(false, option)); } ytcenter.player.resizeUpdater && ytcenter.player.resizeUpdater(); }; ytcenter.player.currentResizeId; ytcenter.player.resizeCallback = []; ytcenter.player.updateResize = (function(){ function scrollToPlayer() { if (!ytcenter.settings.enableResize) return; var scrollElm = (document.getElementById("player-api-legacy") || document.getElementById("player-api")); if (ytcenter.settings.staticHeader) { scrollElm.scrollIntoView(true); } else { var posY = 0, mp = document.getElementById("masthead-positioner"); while (scrollElm != null) { posY += scrollElm.offsetTop; scrollElm = scrollElm.offsetParent; } ytcenter.utils.scrollTop(posY - mp.offsetHeight); } } var scrollToPlayerButtonArrow, scrollToPlayerButton = null; var getSizeById = function(id) { var sizes = ytcenter.settings["resize-playersizes"]; for (var i = 0; i < sizes.length; i++) { if (id === sizes[i].id) { return sizes[i]; } } return { id: "default", config: { align: true, height: "", large: false, scrollToPlayer: false, scrollToPlayerButton: false, width: "" } }; } var updatescrollToPlayerButtonPosition = function(){ if (!ytcenter.settings.enableResize) return; var appbar = document.getElementById("appbar-onebar-upload-group"); if (appbar && !scrollToPlayerButton.parentNode) { appbar.insertBefore(scrollToPlayerButton, appbar.children[0]); } }; var updatescrollToPlayerButtonVisibility = function(){ if (!ytcenter.settings.enableResize) { scrollToPlayerButton.style.display = "none"; return; } try { scrollToPlayerButton.style.bottom = ""; scrollToPlayerButton.style.right = ""; scrollToPlayerButton.style.position = ""; var _s = getSizeById(ytcenter.player.currentResizeId); if (_s.config.scrollToPlayerButton) { scrollToPlayerButton.style.display = "inline-block"; } else { scrollToPlayerButton.style.display = "none"; } var appbar = document.getElementById("appbar-onebar-upload-group"); if (appbar && !scrollToPlayerButton.parentNode) { appbar.insertBefore(scrollToPlayerButton, appbar.children[0]); } } catch (e) { con.error(e); } }; ytcenter.player.updateResize_updatePosition = updatescrollToPlayerButtonPosition; ytcenter.player.updateResize_updateVisibility = updatescrollToPlayerButtonVisibility; scrollToPlayerButtonArrow = document.createElement("img"); scrollToPlayerButtonArrow.className = "yt-uix-button-arrow"; scrollToPlayerButtonArrow.src = "//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"; scrollToPlayerButtonArrow.alt = ""; scrollToPlayerButtonArrow.setAttribute("alt", ""); scrollToPlayerButtonArrow.style.marginLeft = "0"; scrollToPlayerButtonArrow.style.marginRight = "0"; scrollToPlayerButtonArrow.style.display = "inline-block"; scrollToPlayerButton = ytcenter.gui.createYouTubeDefaultButton("SCROLL_TOOLTIP", [scrollToPlayerButtonArrow]); scrollToPlayerButton.className = "yt-uix-button yt-uix-button-default yt-uix-button-size-default yt-uix-button-has-icon yt-uix-button-empty flip yt-uix-tooltip "; scrollToPlayerButton.style.display = "inline-block"; scrollToPlayerButton.style.position = "absolute"; ytcenter.utils.addEventListener(scrollToPlayerButton, "click", function(){ scrollToPlayer(); }, false); return function(){ if (!ytcenter.settings.enableResize) return; var _s = getSizeById(ytcenter.player.currentResizeId); ytcenter.player.resize(_s); if (_s.config.scrollToPlayer && ytcenter.getPage() === "watch" && ((ytcenter.settings.topScrollPlayerEnabled && !ytcenter.settings.topScrollPlayerActivated) || !ytcenter.settings.topScrollPlayerEnabled)) { scrollToPlayer(); } updatescrollToPlayerButtonVisibility(); updatescrollToPlayerButtonPosition(); }; })(); ytcenter.player.isPlayerAligned = function(){ function getSizeById(id) { var sizes = ytcenter.settings["resize-playersizes"]; for (var i = 0; i < sizes.length; i++) { if (id === sizes[i].id) { return sizes[i]; } } return { id: "default", config: { align: true, height: "", large: false, scrollToPlayer: false, scrollToPlayerButton: false, width: "" } }; } if (ytcenter.settings["resize-default-playersize"] === "default") { ytcenter.player.currentResizeId = (ytcenter.settings.player_wide ? ytcenter.settings["resize-large-button"] : ytcenter.settings["resize-small-button"]); } else { ytcenter.player.currentResizeId = ytcenter.settings['resize-default-playersize']; } var playerSize = getSizeById(ytcenter.player.currentResizeId); return playerSize.config.align; }; ytcenter.player.setPlayerSize = function(config){ for (var i = 0; i < ytcenter.settings["resize-playersizes"].length; i++) { if (ytcenter.settings["resize-playersizes"][i].id === config.id) { ytcenter.settings["resize-playersizes"][i] = config; break; } } }; ytcenter.player.getPlayerSize = function(id){ for (var i = 0; i < ytcenter.settings["resize-playersizes"].length; i++) { if (ytcenter.settings["resize-playersizes"][i].id === id) { return ytcenter.settings["resize-playersizes"][i]; } } // default return { id: "default", config: { align: true, height: "", large: false, scrollToPlayer: false, scrollToPlayerButton: false, width: "" } }; }; ytcenter.player.resize = (function(){ var lastResizeId; ytcenter.player.resizeUpdater = function(){ if (!ytcenter.settings.enableResize) return; ytcenter.player.resize(ytcenter.player.getPlayerSize(lastResizeId)); ytcenter.player.updateResize_updateVisibility(); ytcenter.playersResize_updatePosition(); }; ytcenter.player.isSelectedPlayerSizeById = function(id){ if (!ytcenter.settings.enableResize) return; try { if (lastResizeId === id) return true; } catch (e) {} return false; }; var exports_timeout; return function(item){ if (!ytcenter.settings.enableResize) return; if (typeof item !== "undefined") lastResizeId = item.id; if (typeof lastResizeId === "undefined") return; uw.clearTimeout(exports_timeout); // Generate the player size name. var dim = ytcenter.utils.calculateDimensions(item.config.width, item.config.height); var sizeName = null; if (typeof item.config.customName !== "undefined" && item.config.customName !== "") { sizeName = item.config.customName; } else if (isNaN(parseInt(item.config.width)) && isNaN(parseInt(item.config.height))) { sizeName = (item.config.large ? ytcenter.language.getLocale("SETTINGS_RESIZE_LARGE") : ytcenter.language.getLocale("SETTINGS_RESIZE_SMALL")); } else { sizeName = dim[0] + "×" + dim[1]; } // Setting the data attributes to the html tag. document.documentElement.setAttribute("data-ytc-player-size-id", item.id); document.documentElement.setAttribute("data-ytc-player-size-name", sizeName); ytcenter.player._resize(item.config.width, item.config.height, item.config.large, item.config.align); ytcenter.player.updateResize_updateVisibility(); ytcenter.player.updateResize_updatePosition(); ytcenter.utils.each(ytcenter.player.resizeCallback, function(i, func){ func(); }); }; })(); ytcenter.player.ratio = 16/9; ytcenter.player.setRatio = function(ratio){ con.log("[Player Ratio] Player ratio set to " + ratio); ytcenter.player.ratio = ratio; }; ytcenter.player._resize = (function(){ var _width = ""; var _height = ""; var _large = true; var _align = true; var _playlist_toggled = false; var _playerHeight = 0; var player_ratio = 16/9; var playerBarHeight = 30; var playerBarHeightNone = 0; var playerBarHeightProgress = 3; var playerBarHeightBoth = 35; var maxInsidePlayerWidth = 1040; var minInsidePlayerWidth = 1003; var minSmallPlayer = 640; var maxWatchNonStageWidth0 = 1254; var maxWatchNonStageWidth1 = 1254; var maxWatchNonStageWidth2 = 1360; var maxWatchNonStageWidth3 = 1680; var maxWatchStageWidth0 = 1680; var maxWatchNonStagePlayerWidth0 = 854; var maxWatchNonStagePlayerWidth1 = 854; var maxWatchNonStagePlayerWidth2 = 960; var maxWatchNonStagePlayerWidth3 = 1280; var maxWatchStagePlayerWidth0 = 1280; ytcenter.player._updateResize = function(){ if (!ytcenter.settings.enableResize || ytcenter.getPage() !== "watch") return; ytcenter.player._resize(_width, _height, _large, _align); ytcenter.player.updateResize_updateVisibility(); ytcenter.player.updateResize_updatePosition(); }; ytcenter.player.getCurrentPlayerSize = function(){ return { width: _width, height: _height, large: _large, align: _align, playerHeight: _playerHeight }; }; ytcenter.events.addEvent("ui-refresh", function(){ if (!ytcenter.settings.enableResize) return; ytcenter.player._resize(_width, _height, _large, _align); }); ytcenter.events.addEvent("resize-update", function(){ if (!ytcenter.settings.enableResize) return; ytcenter.player._resize(_width, _height, _large, _align); }); ytcenter.utils.addEventListener(window, "resize", (function(){ var timer = null; return function(){ if (!ytcenter.settings.enableResize) return; if (timer !== null) uw.clearTimeout(timer); timer = uw.setTimeout(function(){ ytcenter.events.performEvent("resize-update"); }, 100); }; })(), false); return function(width, height, large, align){ if (!ytcenter.settings.enableResize) return; if (ytcenter.getPage() !== "watch") return; var innerWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth; var innerHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; var clientWidth = document.documentElement.clientWidth || window.innerWidth || document.body.clientWidth; var clientHeight = document.documentElement.clientHeight || window.innerHeight || document.body.clientHeight; var page = document.getElementById("page"); var player = document.getElementById("player-legacy") || document.getElementById("player"); if (ytcenter.settings.ytOnlyStageMode) { if (large) { ytcenter.utils.addClass(page, "watch-stage-mode"); ytcenter.utils.removeClass(page, "watch-non-stage-mode"); } else { ytcenter.utils.addClass(page, "watch-non-stage-mode"); ytcenter.utils.removeClass(page, "watch-stage-mode"); } } else { ytcenter.utils.removeClass(page, "watch-stage-mode watch-non-stage-mode"); } var isWatchNonStage101 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch") && 1294 <= innerWidth && 680 <= innerHeight; var isWatchNonStage102 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch-mini") && 1294 <= innerWidth && 630 <= innerHeight; var isWatchNonStage201 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch-540") && 1400 <= innerWidth && 740 <= innerHeight; var isWatchNonStage202 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch-540-mini") && 1400 <= innerWidth && 690 <= innerHeight; var isWatchNonStage301 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch") && 1720 <= innerWidth && 920 <= innerHeight; var isWatchNonStage302 = ytcenter.utils.hasClass(document.body, "appbar-flexwatch-720-mini") && 1720 <= innerWidth && 920 <= innerHeight; var isWatchStage = ytcenter.utils.hasClass(page, "watch-stage-mode"); var isWatchNonStage = ytcenter.utils.hasClass(page, "watch-non-stage-mode"); var isWatchStage0 = 1320 <= innerWidth && 870 <= innerHeight && isWatchStage && large; var isWatchNonStage0 = 1294 <= innerWidth && 630 <= innerHeight && isWatchNonStage && !large; var isWatchNonStage1 = (isWatchNonStage101 || isWatchNonStage102) && isWatchNonStage && !large; var isWatchNonStage2 = (isWatchNonStage201 || isWatchNonStage202) && isWatchNonStage && !large; var isWatchNonStage3 = (isWatchNonStage301 || isWatchNonStage302) && isWatchNonStage && !large; width = width || ""; height = height || ""; if (typeof large !== "boolean") large = false; if (typeof align !== "boolean") align = false; _width = width; _height = height; _large = large; _align = align; if (ytcenter.player.darkside()) { ytcenter.utils.addClass(document.body, "ytcenter-player-darkside-bg"); } else { ytcenter.utils.removeClass(document.body, "ytcenter-player-darkside-bg"); } // Class Assignment var wc = document.getElementById("watch7-container"); if (wc) { if (large) { ytcenter.utils.addClass(wc, "watch-wide"); } else { ytcenter.utils.removeClass(wc, "watch-wide"); } } if (player) { if (large) { ytcenter.utils.addClass(player, "watch-medium"); if (!_playlist_toggled) { ytcenter.utils.addClass(player, "watch-playlist-collapsed"); } } else { ytcenter.utils.removeClass(player, "watch-medium"); if (ytcenter.utils.hasClass(player, "watch-playlist-collapsed")) { _playlist_toggled = false; } else { _playlist_toggled = true; } ytcenter.utils.removeClass(player, "watch-playlist-collapsed"); } } if (align) { ytcenter.utils.addClass(document.body, "ytcenter-resize-aligned"); ytcenter.utils.removeClass(document.body, "ytcenter-resize-disaligned"); } else { ytcenter.utils.removeClass(document.body, "ytcenter-resize-aligned"); ytcenter.utils.addClass(document.body, "ytcenter-resize-disaligned"); } // Settings the sizes for small and large. If width and height is undefined var stageSize = isNaN(parseInt(width)) && isNaN(parseInt(height)); if (stageSize) { if (isWatchStage0) { width = maxWatchStagePlayerWidth0 + "px"; } else if (isWatchNonStage3) { width = maxWatchNonStagePlayerWidth3 + "px"; } else if (isWatchNonStage2) { width = maxWatchNonStagePlayerWidth2 + "px"; } else if (isWatchNonStage1) { width = maxWatchNonStagePlayerWidth1 + "px"; } else if (isWatchNonStage0) { width = maxWatchNonStagePlayerWidth0 + "px"; } else { width = large ? "854px" : "640px"; } height = ""; } var pbh = 0; var _pbh = 0; var pbh_changed = false; var autohide = ytcenter.settings.autohide; if (ytcenter.html5) { if (ytcenter.player.ratio < 1.35 && autohide === "-1") { autohide = "3" } } else { if (ytcenter.player.config && ytcenter.player.config.args && (typeof ytcenter.player.config.args.autohide === "string" || typeof ytcenter.player.config.args.autohide === "number")) { autohide = ytcenter.player.config.args.autohide; } else { autohide = "3"; } } if (autohide === "0") { pbh = playerBarHeightBoth; _pbh = playerBarHeightBoth; } else if (autohide === "1") { pbh = playerBarHeightNone; _pbh = playerBarHeightNone; } else if (autohide === "2") { pbh = playerBarHeight; _pbh = playerBarHeight; } else if (autohide === "3") { pbh = playerBarHeightProgress; _pbh = playerBarHeightProgress; } else { pbh = playerBarHeight; _pbh = playerBarHeight; } var calcWidth, calcHeight, calcedWidth = false, calcedHeight = false; if (width.match(/%$/) && width.length > 1) { calcWidth = parseInt(width)/100*clientWidth; } else if (width.length > 1) { calcWidth = parseInt(width); } if (height.match(/%$/) && height.length > 1) { var mp = document.getElementById("masthead-positioner"); calcHeight = parseInt(height)/100*clientHeight; if (mp && !ytcenter.settings.staticHeader) { calcHeight -= mp.offsetHeight || mp.clientHeight; } pbh = 0; pbh_changed = true; } else if (height.length > 1) { calcHeight = parseInt(height); } if (!isNaN(calcWidth) && isNaN(calcHeight) && !calcedHeight) { calcedHeight = true; if (ytcenter.player.ratio !== 0) calcHeight = Math.round(calcWidth/ytcenter.player.ratio); else calcHeight = calcWidth; } else if (isNaN(calcWidth) && !isNaN(calcHeight) && !calcedWidth) { calcedWidth = true; if (height.indexOf("%") !== -1 && height.match(/%$/) && height !== "%") { calcWidth = Math.round((calcHeight - _pbh)*ytcenter.player.ratio); } else { calcWidth = Math.round(calcHeight*ytcenter.player.ratio); } } if (!isNaN(calcWidth) && align && large) { var ratio = calcWidth/calcHeight; var maxWidth = Math.min(calcWidth, maxInsidePlayerWidth); var minWidth = Math.min(calcWidth, minInsidePlayerWidth); if (clientWidth > maxWidth) { calcWidth = maxWidth; } else if (clientWidth < minWidth) { calcWidth = minWidth; } else { calcWidth = clientWidth; } if (!isNaN(calcHeight) && typeof calcHeight === "number") { if (ratio !== 0 && isFinite(ratio)) { calcHeight = Math.round(calcWidth/ratio); } } else { if (ytcenter.player.ratio !== 0) { calcHeight = Math.round(calcWidth/ytcenter.player.ratio); } else { calcHeight = calcWidth; } } } if (isNaN(calcWidth)) calcWidth = 0; if (isNaN(calcHeight)) calcHeight = 0; // Player Dimension var sidebar = document.getElementById("watch7-sidebar"), playerAPI = document.getElementById("player-api-legacy") || document.getElementById("player-api"), theaterBackground = document.getElementById("theater-background"), content = document.getElementById("watch7-main-container"), contentMain = document.getElementById("watch7-main"), playlist = document.getElementById("watch7-playlist-tray-container"), playerWidth = Math.round(calcWidth), playerHeight = Math.round(calcHeight + pbh), playlist_el = document.getElementById("playlist-legacy") || document.getElementById("playlist"); if (stageSize && (isWatchStage0 || isWatchNonStage3 || isWatchNonStage2 || isWatchNonStage1 || isWatchNonStage0)) { var maxWidth = minSmallPlayer; var minWidth = minSmallPlayer; if (isWatchStage0) { maxWidth = maxWatchStagePlayerWidth0; } else if (isWatchNonStage3) { maxWidth = maxWatchNonStagePlayerWidth3; } else if (isWatchNonStage2) { maxWidth = maxWatchNonStagePlayerWidth2; } else if (isWatchNonStage1) { maxWidth = maxWatchNonStagePlayerWidth1; } else if (isWatchNonStage0) { maxWidth = maxWatchNonStagePlayerWidth0; } if (clientWidth > maxWidth) { calcWidth = maxWidth; } else { calcWidth = minWidth; } if (ytcenter.player.ratio !== 0) { calcHeight = Math.round(calcWidth/ytcenter.player.ratio); } else { calcHeight = calcWidth; } } if (player && player.className && player.className.indexOf("watch-multicamera") !== -1 && !ytcenter.html5) { playerHeight = playerHeight + 80; } if (theaterBackground) { theaterBackground.style.height = playerHeight + "px"; } document.documentElement.setAttribute("data-ytc-player-size-width", width); // The width of the player as given by the player size document.documentElement.setAttribute("data-ytc-player-size-height", height); // The height of the player as given by the player size document.documentElement.setAttribute("data-ytc-player-size-calc-width", playerWidth); // The calculated width of the player in pixels. document.documentElement.setAttribute("data-ytc-player-size-calc-height", playerHeight); // The calculated height of the player in pixels. document.documentElement.setAttribute("data-ytc-player-size-large", large); // Whether the player is regarded as a large (or medium) sized player by YouTube. document.documentElement.setAttribute("data-ytc-player-size-aligned", align); // Whether the player should be aligned with the content element (description, comments, recommended videos and etc). /* Handle the YouTube player size classes (YouTube Center doesn't differentiate between watch-medium and watch-large as the difference is only the size of the player and that is handled by YouTube Center). */ ytcenter.utils.removeClass(player, "watch-small watch-medium watch-large"); if (player) { if (large) { ytcenter.utils.addClass(player, "watch-large"); player.style.marginTop = "10px"; } else { ytcenter.utils.addClass(player, "watch-small"); player.style.marginTop = ""; } } if (playlist_el) { playlist_el.style.width = (large ? (align && playerWidth < maxInsidePlayerWidth ? maxInsidePlayerWidth : playerWidth) : maxInsidePlayerWidth) + "px"; if (large) { playlist_el.style.width = "auto"; playlist_el.style.minWidth = "1003px"; playlist_el.style.maxWidth = "1040px"; } else { playlist_el.style.minWidth = ""; playlist_el.style.maxWidth = ""; } } if (player) { player.style.position = ""; player.style.left = ""; player.style.marginBottom = ""; if (playerAPI) { playerAPI.style.cssFloat = ""; } if (large && isWatchStage0 && stageSize) { player.style.width = "auto"; player.style.minWidth = minInsidePlayerWidth + "px"; player.style.maxWidth = maxWatchStageWidth0 + "px"; } else if (!large && stageSize) { player.style.width = "auto"; player.style.minWidth = minInsidePlayerWidth + "px"; if (isWatchNonStage3) { player.style.maxWidth = maxWatchNonStageWidth3 + "px"; } else if (isWatchNonStage2) { player.style.maxWidth = maxWatchNonStageWidth2 + "px"; } else if (isWatchNonStage1) { player.style.maxWidth = maxWatchNonStageWidth1 + "px"; } else if (isWatchNonStage0) { player.style.maxWidth = maxWatchNonStageWidth0 + "px"; } else { player.style.maxWidth = maxInsidePlayerWidth + "px"; } } else if (align) { player.style.maxWidth = maxInsidePlayerWidth + "px"; player.style.minWidth = minInsidePlayerWidth + "px"; player.style.width = "auto"; if (playerAPI) { playerAPI.style.cssFloat = "left"; } } else { player.style.maxWidth = ""; player.style.minWidth = ""; player.style.width = (large ? playerWidth + "px" : "auto"); } if (large) { player.style.setProperty("margin-bottom", "28px", "important"); } if (playerAPI) { playerAPI.style.width = playerWidth + "px"; playerAPI.style.height = playerHeight + "px"; _playerHeight = playerHeight; } } // Sidebar if (sidebar) { if (!large && !document.getElementById("watch7-playlist-data")) { var mt = calcHeight + pbh + (document.getElementById("watch7-creator-bar") ? 48 : 0); if (ytcenter.utils.hasClass(document.getElementById("watch7-container"), "watch-branded-banner") && !ytcenter.settings.removeBrandingBanner) mt += 70; sidebar.style.top = "-" + mt + "px"; } else { sidebar.style.top = ""; } } // Playlist if (playlist) { var playlistElement = document.getElementById("watch7-playlist-data"), playlistBar, __playlistWidth = Math.round(calcWidth), __playlistRealWidth = __playlistWidth*0.5; if (__playlistRealWidth < 275) __playlistRealWidth = 275; else if (__playlistRealWidth > 400) __playlistRealWidth = 400; playlist.style.width = (large ? __playlistRealWidth + "px" : "auto"); playlist.style.height = Math.round(calcHeight - (large ? (playerBarHeight - pbh) - 3 : -pbh)) + "px"; if (playlistElement) playlistBar = playlistElement.children[0]; if (playlistBar && playlistBar.children[0] && playlistBar.children[1]) { playlistBar.style.width = (large ? __playlistWidth : maxInsidePlayerWidth) + "px"; playlistBar.children[0].style.width = ((large ? __playlistWidth - __playlistRealWidth : __playlistWidth)) + "px"; playlistBar.children[1].style.width = (large ? "auto" : (maxInsidePlayerWidth - __playlistWidth) + "px"); } if (document.getElementById("playlist-tray") || document.getElementById("playlist-tray-legacy")) { (document.getElementById("playlist-tray") || document.getElementById("playlist-tray-legacy")).style.width = (large ? __playlistWidth : maxInsidePlayerWidth) + "px"; } playlist.style.right = "0"; playlist.style.left = "auto"; } // Player if (playerAPI) { if (width !== "" || height !== "") { playerAPI.style.width = Math.round(calcWidth) + "px"; playerAPI.style.height = Math.round(calcHeight + pbh + (player.className.indexOf("watch-multicamera") !== -1 && !ytcenter.html5 ? 80 : 0)) + "px"; _playerHeight = Math.round(calcHeight + pbh + (player.className.indexOf("watch-multicamera") !== -1 && !ytcenter.html5 ? 80 : 0)); } else { playerAPI.style.width = ""; playerAPI.style.height = ""; document.getElementById("playlist-tray").style.top = ""; } if (calcWidth > maxInsidePlayerWidth) { playerAPI.style.margin = ""; if (align) { playerAPI.style.marginLeft = ""; } else { var wvOffset = $GetOffset(player); var mLeft = Math.round(-(calcWidth - maxInsidePlayerWidth)/2); if (-mLeft > wvOffset[0]) mLeft = -wvOffset[0]; playerAPI.style.marginLeft = mLeft + "px"; } } else { playerAPI.style.marginLeft = ""; playerAPI.style.margin = ""; } if (width === "100%") { playerAPI.style.setProperty("margin-left", "0px", "important"); playerAPI.style.setProperty("margin-right", "0px", "important"); } else { playerAPI.style.marginLeft = ""; playerAPI.style.marginRight = ""; } } var playlistElement = document.getElementById("watch7-playlist-data"), playlistBar; if (playlistElement) playlistBar = playlistElement.children[0]; if (playlistBar && playlistBar.children[0] && playlistBar.children[1]) { playlistBar.style.width = (large ? __playlistWidth : maxInsidePlayerWidth) + "px"; playlistBar.children[0].style.width = ((large ? __playlistWidth - __playlistRealWidth : __playlistWidth)) + "px"; playlistBar.children[1].style.width = (large ? "auto" : (maxInsidePlayerWidth - __playlistWidth) + "px"); var playlistTrayContainer = document.getElementById("watch7-playlist-tray-container"); if (playlistTrayContainer) { var __h = Math.round(calcHeight - (large ? (playerBarHeight - pbh) - 3 : -pbh)); playlistTrayContainer.style.height = __h + "px"; var playlistTray = document.getElementById("watch7-playlist-tray"); if (playlistTray) { playlistTray.style.height = Math.round(__h - (large ? 0 : 27)) + "px"; } playlistTrayContainer.style.width = (large ? __playlistRealWidth : maxInsidePlayerWidth - __playlistWidth) + "px"; if (large) { playlistTrayContainer.style.left = (large ? __playlistWidth - __playlistRealWidth : __playlistWidth) + "px"; } else { playlistTrayContainer.style.left = ""; } var playlistTrayPositioning = document.getElementById("watch7-playlist-tray-positioning"); if (playlistTrayPositioning) { playlistTrayPositioning.style.width = __playlistWidth + "px"; if (align) { playlistTrayPositioning.style.margin = ""; } else { playlistTrayPositioning.style.margin = "0 auto"; } } } } if (!align || !large) { uw.setTimeout(function(){ var player = document.getElementById("player"); player.style.left = ""; }, 0); } }; })(); ytcenter.player.getFPSArray = function(streams){ var arr = []; for (var i = 0, len = streams.length; i < len; i++) { var localFPS = parseInt(streams[i].fps || "30", 10); if (!ytcenter.utils.inArray(arr, localFPS)) { arr.push(localFPS); } } return arr.sort(function(a, b){ return b - a; }); }; ytcenter.player.getHighestFPS = function(streams){ var fps = -1; for (var i = 0, len = streams.length; i < len; i++) { var localfps = parseInt(streams[i].fps || "30", 10); if (fps < localfps) { fps = localfps; } } return fps; }; ytcenter.player.getBestStream = function(streams, dash){ var i, stream = null, vqIndex = ytcenter.player.qualities.length - 1, _vq, _vqIndex, currFPS = -1; for (i = 0; i < streams.length; i++) { if ((dash === 1 && !streams[i].dash) || (dash === 0 && streams[i].dash)) continue; if (streams[i].dash && streams[i].size) { _vq = ytcenter.player.convertDimensionToQuality(streams[i].size); } else if (!streams[i].dash && streams[i].quality) { _vq = streams[i].quality; } var fps = parseInt(streams[i].fps || "30", 10); _vqIndex = $ArrayIndexOf(ytcenter.player.qualities, _vq); if (_vqIndex < vqIndex || (_vqIndex === vqIndex && currFPS < fps)) { stream = streams[i]; vqIndex = _vqIndex; currFPS = fps; } } if (!stream && dash !== -1) return ytcenter.player.getBestStream(streams, -1); return stream; }; ytcenter.player.getHighestStreamQuality = function(streams, dash){ var i, stream = streams[0], stream_dim, tmp_dim; if (!stream) return null; if (stream.dimension && stream.dimension.indexOf("x") !== -1) { stream_dim = stream.dimension.split("x"); stream_dim[0] = parseInt(stream_dim[0], 10); stream_dim[1] = parseInt(stream_dim[1], 10); } else if (stream.size && stream.size.indexOf("x") !== -1) { stream_dim = stream.size.split("x"); stream_dim[0] = parseInt(stream_dim[0], 10); stream_dim[1] = parseInt(stream_dim[1], 10); } else { stream_dim = [0, 0]; } for (i = 1; i < streams.length; i++) { if (!streams[i].dimension && !streams[i].size) continue; if (dash === 0) { if (stream.dash) { stream = streams[i]; continue; } if (streams[i].dash) continue; } else if (dash === 1) { if (!stream.dash) { stream = streams[i]; continue; } if (!streams[i].dash) continue; } if (streams[i].dimension && streams[i].dimension.indexOf("x") !== -1) { tmp_dim = streams[i].dimension.split("x"); tmp_dim[0] = parseInt(tmp_dim[0]); tmp_dim[1] = parseInt(tmp_dim[1]); if (stream_dim[1] < tmp_dim[1]) { stream_dim = tmp_dim; stream = streams[i]; } } else if (streams[i].size && streams[i].size.indexOf("x") !== -1) { tmp_dim = streams[i].size.split("x"); tmp_dim[0] = parseInt(tmp_dim[0]); tmp_dim[1] = parseInt(tmp_dim[1]); if (stream_dim[1] < tmp_dim[1]) { stream_dim = tmp_dim; stream = streams[i]; } } } return stream; }; ytcenter.player.getQualityByDimensionHTML5 = function(width, height) { var qualityList = ["auto", "highres", "hd1440", "hd1080", "hd720", "large", "medium", "small", "tiny"], tabel = { auto: [0, 0], tiny: [256, 144], light: [426, 240], small: [426, 240], medium: [640, 360], large: [854, 480], hd720: [1280, 720], hd1080: [1920, 1080], hd1440: [2560, 1440], highres: [3840, 2160] }, quality = "tiny", i, q; for (i = 2; i < qualityList.length; i++) { q = tabel[qualityList[i]]; if (width > q[0] && height >= q[1] || width >= q[0] && height > q[1]) { return qualityList[i - 1]; } } return quality } ytcenter.player.getQualityByDimension = function(width, height) { if (height > 1728 || width > 3072) { return "highres"; } if (height > 1152 || width > 2048) { return "hd1440"; } if (height > 720 || width > 1280) { return "hd1080"; } if (height > 480 || width > 854) { return "hd720"; } if (height > 360 || width > 640) { return "large"; } if (height > 240 || width > 427) { return "medium"; } if (height > 144 || width > 256) { return "small"; } return "tiny"; } ytcenter.player.convertDimensionToQuality = function(size){ if (!size) return "auto"; size = size.split("x"); return ytcenter.player.getQualityByDimension(size[0], size[1]); }; ytcenter.player.convertDimensionToQualityHTML5 = function(size){ if (!size) return "auto"; size = size.split("x"); return ytcenter.player.getQualityByDimensionHTML5(size[0], size[1]); }; ytcenter.player.qualities = ["highres", "hd1440", "hd1080", "hd720", "large", "medium", "small", "tiny", "auto"]; ytcenter.player.qualityDimensions = ["3840x2160", "2560x1440", "1920x1080", "1280x720", "854x480", "640x360", "640x360"]; ytcenter.player.getQualityDimension = function(vq){ if (vq === "auto") return null; var i = 0; for (i = 0; i < ytcenter.player.qualities.length; i++) { if (ytcenter.player.qualities[i] === vq) { return ytcenter.player.qualityDimensions[i]; } } return null; }; ytcenter.player.getQuality = function(vq, streams, dash){ var _vq = "auto", priority = ['auto', 'tiny', 'small', 'medium', 'large', 'hd720', 'hd1080', 'hd1440', 'highres'], a = document.createElement("video"), cpt = a && a.canPlayType, currentIndex = 0, quality, qualityIndex, preferedIndex; if (typeof streams === "undefined") return _vq; if (typeof dash === "undefined") { if (ytcenter.getPage() === "watch") { dash = ytcenter.settings.dashPlayback; } else if (ytcenter.getPage() === "embed") { dash = ytcenter.settings.embed_dashPlayback; } else if (ytcenter.getPage() === "channel") { dash = ytcenter.settings.channel_dashPlayback; } } if (ytcenter.html5 && !cpt) { con.log("[getQuality] The HTML5 player is not supported by this browser!"); return _vq; } for (var i = 0; i < streams.length; i++) { if (!streams[i]) continue; // This stream doesn't exist... if (ytcenter.html5 && !a.canPlayType(streams[i].type.split(";")[0]).replace(/no/, '')) continue; // Browser doesn't support this format if (dash && (!streams[i].dash || !streams[i].size)) continue; if (!dash && streams[i].dash) continue; if (dash) { if (ytcenter.html5) { quality = ytcenter.player.convertDimensionToQualityHTML5(streams[i].size); } else { quality = ytcenter.player.convertDimensionToQuality(streams[i].size); } } else { quality = streams[i].quality; } qualityIndex = $ArrayIndexOf(priority, quality); preferedIndex = $ArrayIndexOf(priority, vq); if (qualityIndex <= preferedIndex && qualityIndex > currentIndex) { _vq = quality; currentIndex = qualityIndex; } } con.log("[Player:getQuality] Most preferred available quality: " + _vq); return _vq; }; ytcenter.player.parseThumbnailStream = function(specs){ var parts = specs.split("|"), baseURL = parts[0], levels = [], i, a, b; for (i = 1; i < parts.length; i++) { a = parts[i].split("#"); b = { width: parseInt(a[0]), height: parseInt(a[1]), frames: parseInt(a[2]), columns: parseInt(a[3]), rows: parseInt(a[4]), interval: parseInt(a[5]), urlPattern: a[6], signature: a[7] }; b.numMosaics = Math.ceil(b.frames / (b.rows * b.columns)); b.getMosaic = (function(c){ return function(frame){ return Math.floor(frame/(c.rows*c.columns)); }; })(b); b.getURLS = (function(c, index){ return function(){ var arr = [], j; for (j = 0; j < c.numMosaics; j++) { arr.push(baseURL.replace("$L", index).replace("$N", c.urlPattern).replace("$M", j) + "?sigh=" + c.signature); } return arr; }; })(b, i - 1); b.getRect = (function(c){ return function(frame, maxDim){ if (frame < 0 || (c.frames && frame >= c.frames)) return null; var scale = 1, a = frame % (c.rows * c.columns), _x, x, _y, y, width = c.width - 2, height = c.height, iw, ih; if (maxDim && width > 0 && height > 0) { if (maxDim.width > 0 && maxDim.height > 0) scale = Math.min(maxDim.width/width, maxDim.height/height); else if (maxDim.width === 0) scale = maxDim.height/height; else if (maxDim.height === 0) scale = maxDim.width/width; } _x = (c.width * (a % c.columns)); x = _x*scale; _y = (c.height * Math.floor(a / c.rows)); y = _y*scale; width = width*scale, height = height*scale, iw = c.width*c.columns*scale ih = c.height*c.rows*scale; return { x: Math.round(x), y: Math.round(y), _x: Math.round(_x), _y: Math.round(_y), width: Math.round(width), height: Math.round(height), imageWidth: Math.round(iw), imageHeight: Math.round(ih) }; }; })(b); b.getURL = (function(c, index){ return function(frame){ return baseURL.replace("$L", index).replace("$N", c.urlPattern).replace("$M", c.getMosaic(frame)) + "?sigh=" + c.signature; }; })(b, i - 1); levels.push(b); } return { baseURL: baseURL, levels: levels }; }; ytcenter.player._original_update = undefined; ytcenter.player._appliedBefore = false; ytcenter.player._onPlayerLoadedBefore = false; ytcenter.player.setPlayerType = function(type){ function setType(api, type) { var playerType = null; if (api && typeof api.getPlayerType === "function" && (playerType = api.getPlayerType()) === type) { con.log("[Player:setPlayerType] Type is already " + type + "!"); return; } con.log("[Player:setPlayerType] Setting player type from " + playerType + " to " + type); if (api && typeof api.writePlayer === "function") { api.writePlayer(type); } } con.log("[Player:setPlayerType] Requesting player type change to " + type); try { if (type !== "html5" && type !== "flash") { con.error("[Player:setPlayerType] Invalid type: " + type); return; } if (ytcenter.player.isLiveStream()) { con.log("[Player:setPlayerType] Is disabled on live streams!"); return; } if (ytcenter.player.isOnDemandStream()) { con.log("[Player:setPlayerType] Is disabled on live streams!"); return; } var api = ytcenter.player.getAPI(); if (api) { setType(api, type); } else { var called = false; var cb = function(api){ if (!api || called) return; called = true; if (type === "flash") ytcenter.player.disableHTML5Tick(); setType(api, type); }; con.log("[Player:setPlayerType] API isn't ready!"); if (type === "flash") ytcenter.player.disableHTML5(); //ytcenter.utils.addClass(document.body, "ytcenter-disable-html5"); ytcenter.player.listeners.addEventListener("onReady", cb); } } catch (e) { con.error(e); } }; ytcenter.player.disableHTML5Tick = function(){ if (ytcenter.player.disableHTML5_timeout) { uw.clearTimeout(ytcenter.player.disableHTML5_timeout); ytcenter.player.disableHTML5_timeout = null; } ytcenter.utils.removeClass(document.body, "ytcenter-disable-html5"); }; ytcenter.player.disableHTML5_timeout = null; ytcenter.player.disableHTML5 = function(){ var a = document.getElementsByClassName("video-stream"); if (a.length > 0 && a[0]) //a[0].pause(); // Slower aproach, but will not throw errors (we want the faster method). a[0].src = ""; // this can cause YouTube to throw errors, but we're doing it anyway. ytcenter.utils.addClass(document.body, "ytcenter-disable-html5"); if (ytcenter.player.disableHTML5_timeout) { uw.clearTimeout(ytcenter.player.disableHTML5_timeout); ytcenter.player.disableHTML5_timeout = null; } ytcenter.player.disableHTML5_timeout = uw.setTimeout(function(){ ytcenter.utils.removeClass(document.body, "ytcenter-disable-html5"); }, 2000); }; ytcenter.player.updateFlashvars = function(player, config){ if (!config || !config.args || !player) return; var flashvars = "", key; for (key in config.args) { if (config.args.hasOwnProperty(key) && key !== "__exposedProps__") { if (flashvars !== "") flashvars += "&"; flashvars += encodeURIComponent(key) + "=" + encodeURIComponent(config.args[key]); } } player.setAttribute("flashvars", flashvars); }; ytcenter.player.isHTML5 = function(){ var movie_player = document.getElementById("movie_player"), cfg = ytcenter.player.getConfig(), api = ytcenter.player.getAPI(); var isHTML5 = (movie_player && movie_player.tagName === "DIV") || cfg.html5 || (api && api.getPlayerType && api.getPlayerType() === "html5"); return isHTML5; }; ytcenter.player.updated = false; ytcenter.player.update = function(config){ if (ytcenter.getPage() === "watch" && !config.args.url_encoded_fmt_stream_map && !config.args.adaptive_fmts && config.args.live_playback !== 1) { config = ytcenter.player.modifyConfig("watch", ytcenter.player.getRawPlayerConfig()); ytcenter.player.setConfig(config); } if (ytcenter.player.isHTML5() || ytcenter.player.updated) return; try { var player = document.getElementById("movie_player") || document.getElementById("player1"), clone; con.log("[Player Update] Checking if player exist!"); if ((player && player.tagName.toLowerCase() == "embed") || ytcenter.player._update_onYouTubeReady) { ytcenter.player.updated = false; ytcenter.player.updateFlashvars(player, config); if (ytcenter.getPage() === "watch") { if (ytcenter.settings.flashWMode !== "none") { player.setAttribute("wmode", ytcenter.settings.flashWMode); } } else if (ytcenter.getPage() === "embed") { if (ytcenter.settings.embed_flashWMode !== "none") { player.setAttribute("wmode", ytcenter.settings.embed_flashWMode); } } else if (ytcenter.getPage() === "channel") { if (ytcenter.settings.channel_flashWMode !== "none") { player.setAttribute("wmode", ytcenter.settings.channel_flashWMode); } } clone = player.cloneNode(true); clone.style.display = ""; player.style.display = "none"; player.src = ""; player.parentNode.replaceChild(clone, player); player = clone; con.log("[Player Update] Player has been cloned and replaced!"); } else { //uw.setTimeout(function(){ ytcenter.player.update(config); }, 100); } } catch (e) { con.error(e); } }; ytcenter.effects = {}; ytcenter.effects.playerGlow = (function(){ function inCorrectMode() { return (glowEffectOnPlayer === "both" || (ytcenter.player.isLightOff && glowEffectOnPlayer === "only-lights-off") || (!ytcenter.player.isLightOff && glowEffectOnPlayer === "only-without-lights-off")); } function playerStateChange(s) { state = s; if (state === 1 && enabled && inCorrectMode()) { stopPlaying(); onPlaying(); } else { stopPlaying(); } } function update() { var api = ytcenter.player.getAPI(); if (api && typeof api.getPlayerState === "function") { playerStateChange(api.getPlayerState()); } } function getPlayerAPIElement() { return document.getElementById("player-api"); } function getPlayerWrapperOverlay() { return document.getElementById("movie_player") || document.getElementById("player-api") || document.getElementById("player"); } function getPlayerWrapper() { return document.getElementById("player-api") || document.getElementById("player") || document.getElementById("movie_player"); } function getCorrectPlayerElement() { return ((glowEffectOnPlayer === "both" || glowEffectOnPlayer === "only-lights-off") ? playerElementOverlay : playerElement); } function onPlaying() { html5Player = ytcenter.utils.getHTML5Player(); playerElement = getPlayerWrapper(); playerElementOverlay = getPlayerWrapperOverlay(); correctPlayerElement = getCorrectPlayerElement(); playerAPIElement = getPlayerAPIElement(); if (playerAPIElement && (glowEffectOnPlayer === "both" || glowEffectOnPlayer === "only-lights-off")) { playerAPIElement.style.overflow = "visible"; } if (!container.parentNode) { playerAPIElement.appendChild(container); } con.log("[Player Glow] In correct mode? " + inCorrectMode()); /* We want to make sure that the html5 player exist */ if (html5Player && enabled && inCorrectMode()) { allowGlowUpdate = true; /* Let's get this running */ onRequestGlow(); } } function stopPlaying() { /* Remove the glow if the player was unstartet or ended (we don't need to do this if it's only paused) */ if (state < 1 || !inCorrectMode()) { if (!playerElement) playerElement = getPlayerWrapper(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (!playerElementOverlay) playerElementOverlay = getPlayerWrapperOverlay(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (!correctPlayerElement) correctPlayerElement = getCorrectPlayerElement(); if (!playerAPIElement) playerAPIElement = getPlayerAPIElement(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (playerAPIElement && (glowEffectOnPlayer === "both" || glowEffectOnPlayer === "only-lights-off")) { playerAPIElement.style.overflow = ""; } removeMultiGlow(); removeGlow(); } else if (state === 1) { if (!playerElement) playerElement = getPlayerWrapper(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (!playerElementOverlay) playerElementOverlay = getPlayerWrapperOverlay(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (!correctPlayerElement) correctPlayerElement = getCorrectPlayerElement(); if (!playerAPIElement) playerAPIElement = getPlayerAPIElement(); // Make sure that the player wrapper is referenced so that the glow can be removed. if (playerAPIElement && (glowEffectOnPlayer === "both" || glowEffectOnPlayer === "only-lights-off")) { playerAPIElement.style.overflow = ""; } removeMultiGlow(); removeGlow(); } /* We don't need the references */ html5Player = null; playerElement = null; playerElementOverlay = null; correctPlayerElement = null; playerAPIElement = null; if (timeoutId) { uw.clearTimeout(timeoutId); timeoutId = null; } if (requestFrameId) { cancelFrame(requestFrameId); requestFrameId = null; } allowGlowUpdate = false; } function onRequestGlow(now) { if (state !== 1) return; var w = widthF; var h = heightF; /* Resize the canvas to the video */ width = html5Player.clientWidth || html5Player.offsetWidth; height = html5Player.clientHeight || html5Player.offsetHeight; container.style.width = width + "px"; container.style.height = height + "px"; /* Factor the size down of the canvas to increase the performance */ widthF = canvas.width = width*factor; heightF = canvas.height = height*factor; if (widthF === 0 || heightF === 0) return; /* Calculate the amount of pixels used */ if (w !== widthF || h !== heightF) { totalPixels = widthF*heightF; pixelCount = Math.floor(totalPixels/pixelInterval); clearGlowCache(); } /* Handle the delta time */ now = now || ytcenter.utils.now(); lastTimestamp = lastTimestamp || now; var dt = (now - lastTimestamp)/1000; lastTimestamp = now; if (multiglow) { removeGlow(); var blocks = calculateBlocks(width, height); /* Draw the video frame onto the canvas */ drawVideoOnCanvas(); /* Get the frame data (Unescapable bottleneck) */ var imageData = ctx.getImageData(0, 0, widthF, heightF); /* Get the data reference */ var data = imageData.data; for (var i = 0, len = blocks.length; i < len; i++) { applyGlowOnBlock(i, blocks[i], data, blur, spread, opacity); } } else { removeMultiGlow(); /* We want the average color */ color = getAverageColor(dt, color); /* Apply the new rgb values to the glow */ applyGlow(color, blur, spread, opacity); } if (allowGlowUpdate) { /* We really want to run this again to change the color of the glow for the next frame */ if (interval >= 0) { timeoutId = uw.setTimeout(onRequestGlow, interval); } else { requestFrameId = reqFrame(onRequestGlow); } } } function clearGlowCache() { blockCache = []; for (var i = 0, len = blockGlowCache.length; i < len; i++) { if (blockGlowCache[i].parentNode) { blockGlowCache[i].parentNode.removeChild(blockGlowCache[i]); } } blockGlowCache = []; } function drawVideoOnCanvas() { /* Write video data to canvas */ ctx.drawImage(html5Player, 0, 0, widthF, heightF); } function calculateBlock(x, y, width, height) { if (blockCache[x] && blockCache[x][y]) { return blockCache[x][y]; } var block = []; for (var i = 0, len = width*height; i < len; i++) { block.push([x + i%width, y + Math.floor(i/width)]); } if (!blockCache[x]) blockCache[x] = []; blockCache[x][y] = block; return block; } function calculateBlocks() { var blocks = []; var corners = depth/blockInterval; corners = 0; /* Top */ for (var i = 0, len = width/blockInterval - corners; i < len; i++) { var pos = { x: i*blockInterval, y: 0, width: blockInterval, height: depth }; if (pos.x + pos.width > width) { pos.width = width - pos.x; } pos.xF = Math.floor(pos.x*factor); pos.yF = Math.floor(pos.y*factor); pos.widthF = Math.floor(pos.width*factor); pos.heightF = Math.floor(pos.height*factor); pos.data = calculateBlock(pos.xF, pos.yF, pos.widthF, pos.heightF); blocks.push(pos); } /* Bottom */ for (var i = corners, len = width/blockInterval; i < len; i++) { var pos = { x: i*blockInterval, y: height - depth, width: blockInterval, height: depth }; if (pos.x + pos.width > width) { pos.width = width - pos.x; } pos.xF = Math.floor(pos.x*factor); pos.yF = Math.floor(pos.y*factor); pos.widthF = Math.floor(pos.width*factor); pos.heightF = Math.floor(pos.height*factor); pos.data = calculateBlock(pos.xF, pos.yF, pos.widthF, pos.heightF); blocks.push(pos); } /* Left */ for (var i = corners, len = height/blockInterval; i < len; i++) { var pos = { x: 0, y: i*blockInterval, width: depth, height: blockInterval }; if (pos.y + pos.height > height) { pos.height = height - pos.y; } pos.xF = Math.floor(pos.x*factor); pos.yF = Math.floor(pos.y*factor); pos.widthF = Math.floor(pos.width*factor); pos.heightF = Math.floor(pos.height*factor); pos.data = calculateBlock(pos.xF, pos.yF, pos.widthF, pos.heightF); blocks.push(pos); } /* Right */ for (var i = 0, len = height/blockInterval - corners; i < len; i++) { var pos = { x: width - depth, y: i*blockInterval, width: depth, height: blockInterval }; if (pos.y + pos.height > height) { pos.height = height - pos.y; } pos.xF = Math.floor(pos.x*factor); pos.yF = Math.floor(pos.y*factor); pos.widthF = Math.floor(pos.width*factor); pos.heightF = Math.floor(pos.height*factor); pos.data = calculateBlock(pos.xF, pos.yF, pos.widthF, pos.heightF); blocks.push(pos); } return blocks; } function getAverageColorForBlock(pixels, data) { var minx = -1; var miny = -1; var maxx = -1; var maxy = -1; for (var i = 0, len = pixels.length; i < len; i++) { if (pixels[i][0] < minx || minx === -1) { minx = pixels[i][0]; } if (pixels[i][0] > maxx || maxx === -1) { maxx = pixels[i][0]; } if (pixels[i][1] < miny || miny === -1) { miny = pixels[i][1]; } if (pixels[i][1] > maxy || maxy === -1) { maxy = pixels[i][1]; } } /* Prepare variables for the loop */ var r = 0, g = 0, b = 0, idx, i = pixels.length - 1; var pixelCount = Math.floor(pixels.length/pixelInterval); /* Loop through every pixel */ while (i > 0) { idx = Math.floor(pixels[i][0] + pixels[i][1]*widthF) << 2; r += data[idx]; g += data[idx + 1]; b += data[idx + 2]; i -= pixelInterval; } /* We are dividing by a variable that could be 0 */ if (pixelCount > 0) { /* Average the color */ r = Math.floor(r/pixelCount); g = Math.floor(g/pixelCount); b = Math.floor(b/pixelCount); } /* Make sure that the rgb color doesn't go under 0 or over 255 */ if (r < 0) r = 0; if (r > 255) r = 255; if (g < 0) g = 0; if (g > 255) g = 255; if (b < 0) b = 0; if (b > 255) b = 255; return { r: r, g: g, b: b }; } function getAverageColor(dt, lastColor) { drawVideoOnCanvas(); /* Get the frame data (Unescapable bottleneck) */ var imageData = ctx.getImageData(0, 0, widthF, heightF); /* Get the data reference */ var data = imageData.data; /* Prepare variables for the loop */ var i, r = 0, g = 0, b = 0; /* Loop through every pixel */ for (i = 0; i < totalPixels; i += pixelInterval) { idx = i << 2; r += data[idx]; g += data[idx + 1]; b += data[idx + 2]; } /* We are dividing by a variable that could be 0 */ if (pixelCount > 0) { /* Average the color */ r = Math.floor(r/pixelCount); g = Math.floor(g/pixelCount); b = Math.floor(b/pixelCount); } if (lastColor && transition > 0) { /* Make sure that it can't transition past the destination */ var dest = Math.min(dt/transition, 1); /* Transition from color to another */ r = lastColor.r + (r - lastColor.r)*dest; g = lastColor.g + (g - lastColor.g)*dest; b = lastColor.b + (b - lastColor.b)*dest; } /* Make sure that the rgb color doesn't go under 0 or over 255 */ if (r < 0) r = 0; if (r > 255) r = 255; if (g < 0) g = 0; if (g > 255) g = 255; if (b < 0) b = 0; if (b > 255) b = 255; return { r: r, g: g, b: b }; } function applyGlowOnBlock(i, block, data, blur, radius, opacity) { var color = getAverageColorForBlock(block.data, data); var el; if (blockGlowCache[i]) { el = blockGlowCache[i]; } else { el = document.createElement("div"); el.className = "gpu"; el.style.position = "absolute"; el.style.top = block.y + "px"; el.style.left = block.x + "px"; el.style.width = block.width + "px"; el.style.height = block.height + "px"; el.style.zIndex = (i%2 ? "52" : "53"); container.appendChild(el); blockGlowCache[i] = el; } var value = "0px 0px " + blur + "px " + radius + "px rgba(" + Math.floor(color.r) + ", " + Math.floor(color.g) + ", " + Math.floor(color.b) + ", " + opacity + ")"; el.style.setProperty("-webkit-box-shadow", value); el.style.setProperty("-moz-box-shadow", value); el.style.setProperty("box-shadow", value); } function applyGlow(color, blur, radius, opacity) { var value = "0px 0px " + blur + "px " + radius + "px rgba(" + Math.floor(color.r) + ", " + Math.floor(color.g) + ", " + Math.floor(color.b) + ", " + opacity + ")"; correctPlayerElement.style.setProperty("-webkit-box-shadow", value); correctPlayerElement.style.setProperty("-moz-box-shadow", value); correctPlayerElement.style.setProperty("box-shadow", value); } function removeGlow(){ playerElement.style.setProperty("-webkit-box-shadow", ""); playerElement.style.setProperty("-moz-box-shadow", ""); playerElement.style.setProperty("box-shadow", ""); playerElementOverlay.style.setProperty("-webkit-box-shadow", ""); playerElementOverlay.style.setProperty("-moz-box-shadow", ""); playerElementOverlay.style.setProperty("box-shadow", ""); } function removeMultiGlow() { if (container.parentNode) { container.parentNode.removeChild(container); } } function setEnabled(e) { enabled = !!e; update(); } function setOption(key, value) { switch (key) { case "pixelInterval": pixelInterval = value; if (pixelInterval <= 0) pixelInterval = 1; totalPixels = width * height; pixelCount = Math.floor(totalPixels/pixelInterval); break; case "interval": interval = value; break; case "transition": transition = value; break; case "blur": blur = value; break; case "spread": spread = value; break; case "opacity": opacity = value; break; case "glowEffectOnPlayer": glowEffectOnPlayer = value; break; case "multiglow": multiglow = value; break; case "depth": depth = value; break; case "blockInterval": blockInterval = value; break; case "factor": factor = value/100; break; } update(); } var reqFrame = uw.requestAnimationFrame || uw.mozRequestAnimationFrame || uw.webkitRequestAnimationFrame || uw.msRequestAnimationFrame; var cancelFrame = window.cancelAnimationFrame || window.mozCancelAnimationFrame; var timeoutId = null; var requestFrameId = null; var enabled = false; var width, height; var factor = 0.5; var widthF, heightF; // Factored var state = -1; var canvas = document.createElement("canvas"); var ctx = canvas.getContext("2d"); ctx.webkitImageSmoothingEnabled = false; ctx.mozImageSmoothingEnabled = false; ctx.msImageSmoothingEnabled = false; ctx.oImageSmoothingEnabled = false; ctx.imageSmoothingEnabled = false; var pixelCount = null; var totalPixels = null; var blockGlowCache = []; var blockCache = []; var container = document.createElement("div"); container.style.position = "absolute"; container.style.top = "0"; container.style.left = "0"; var html5Player = null; var playerElement = null; var playerElementOverlay = null; var correctPlayerElement = null; var playerAPIElement = null; var color = null; var lastTimestamp = null; /* Options */ var pixelInterval = 100000; /* Iterate every nth pixel instead of every single pixel */ var interval = -1; /* If interval is -1 it will use requestAnimationFrame instead of setTimeout */ var transition = 0; /* The transition time in seconds */ var blur = 15; var spread = 5; var opacity = .75; var glowEffectOnPlayer = "both"; var multiglow = true; var depth = 10; var blockInterval = 40; var allowGlowUpdate = false; ytcenter.player.listeners.addEventListener("onStateChange", playerStateChange); return { setEnabled: setEnabled, setOption: setOption, update: update }; })(); ytcenter.parseStreams = function(playerConfig){ if (playerConfig.url_encoded_fmt_stream_map === "") return []; var parser1 = function(f){ var a, r = []; try { var a = f.split(","); for (var i = 0; i < a.length; i++) { var b = a[i].split("/"); var itag = b.shift(); var dimension = b.shift(); var minMajorFlashVersion = b.shift(); var minMinorFlashVersion = b.shift(); var revisionVersion = b.shift(); r.push({ itag: itag, dimension: dimension, flashVersion: { minMajor: minMajorFlashVersion, minMinor: minMinorFlashVersion, revision: revisionVersion } }); } } catch (e) { con.error("[parseStreams] Error =>"); con.error(e); } return r; }; var parser2 = function(u){ var a, b = []; try { a = u.split(","); for (var i = 0; i < a.length; i++) { var c = {}; var d = a[i].split("&"); for (var j = 0; j < d.length; j++) { var e = d[j].split("="); c[e[0]] = unescape(e[1]); if (e[0] === "type") c[e[0]] = c[e[0]].replace(/\+/g, " "); } b.push(c); } } catch (e) { con.error("[parseStreams] Error =>"); con.error(e); } return b; }; var parser3 = function(u){ if (!u) return []; var a = u.split(","); var b = []; for (var i = 0; i < a.length; i++) { var c = {}; var d = a[i].split("&"); for (var j = 0; j < d.length; j++) { var e = d[j].split("="); c[e[0]] = unescape(e[1]); if (e[0] === "type") c[e[0]] = c[e[0]].replace(/\+/g, " "); } b.push(c); } return b; }; var fmt = parser1(playerConfig.fmt_list); var streams = parser2(playerConfig.url_encoded_fmt_stream_map); var adaptive_fmts = parser3(playerConfig.adaptive_fmts); var a = [], i; for (i = 0; i < streams.length; i++) { var fl = null; for (var j = 0; j < fmt.length; j++) { if (streams[i].itag !== fmt[j].itag) continue; fl = fmt[j]; break; } streams[i].dash = false; if (fl == null) { a.push(streams[i]); } else { var coll = streams[i]; coll.dimension = fl.dimension; coll.flashVersion = fl.flashVersion; a.push(coll); } } for (i = 0; i < adaptive_fmts.length; i++) { adaptive_fmts[i].dash = true; a.push(adaptive_fmts[i]); } return a; }; ytcenter.classManagement = {}; ytcenter.classManagement.applyClassesExceptElement = function(el, url){ if (ytcenter.page === "embed") return; if (url) url = ytcenter.utils.getURL(url); else url = loc; var i; for (i = 0; i < ytcenter.classManagement.db.length; i++) { if (ytcenter.classManagement.db[i].element() && ytcenter.classManagement.db[i].element() !== el) { if (ytcenter.classManagement.db[i].condition(url)) ytcenter.utils.addClass(ytcenter.classManagement.db[i].element(), ytcenter.classManagement.db[i].className); else ytcenter.utils.removeClass(ytcenter.classManagement.db[i].element(), ytcenter.classManagement.db[i].className); } else if (!ytcenter.classManagement.db[i].element()) { //con.warn("[Element Class Management] Element does not exist!", ytcenter.classManagement.db[i]); } } }; ytcenter.classManagement.applyClassesForElement = function(el, url){ var i, elm; if (ytcenter.page === "embed") return; if (url) url = ytcenter.utils.getURL(url); else url = loc; for (i = 0; i < ytcenter.classManagement.db.length; i++) { elm = ytcenter.classManagement.db[i].element(); if (elm === el) { if (ytcenter.classManagement.db[i].condition(url)) { ytcenter.utils.addClass(elm, ytcenter.classManagement.db[i].className); } else { ytcenter.utils.removeClass(elm, ytcenter.classManagement.db[i].className); } } } }; ytcenter.classManagement.applyClasses = function(url){ if (ytcenter.page === "embed") return; if (url) url = ytcenter.utils.getURL(url); else url = loc; var i; for (i = 0; i < ytcenter.classManagement.db.length; i++) { if (ytcenter.classManagement.db[i].element()) { if (ytcenter.classManagement.db[i].condition(url)) ytcenter.utils.addClass(ytcenter.classManagement.db[i].element(), ytcenter.classManagement.db[i].className); else ytcenter.utils.removeClass(ytcenter.classManagement.db[i].element(), ytcenter.classManagement.db[i].className); } else { //con.warn("[Element Class Management] Element does not exist!", ytcenter.classManagement.db[i]); } } }; ytcenter.classManagement.getClassesForElementById = function(id, url){ if (ytcenter.page === "embed") return; if (url) url = ytcenter.utils.getURL(url); else url = loc; var i, a = []; for (i = 0; i < ytcenter.classManagement.db.length; i++) { if (ytcenter.classManagement.db[i].element()) { if (ytcenter.classManagement.db[i].element().getAttribute("id") === id && ytcenter.classManagement.db[i].condition(url)) a.push(ytcenter.classManagement.db[i].className); } else { //con.warn("[Element Class Management] Element does not exist!", ytcenter.classManagement.db[i]); } } return a.join(" "); }; ytcenter.classManagement.getClassesForElementByTagName = function(tagname, url){ if (ytcenter.page === "embed") return; if (url) url = ytcenter.utils.getURL(url); else url = loc; var i, a = []; for (i = 0; i < ytcenter.classManagement.db.length; i++) { if (ytcenter.classManagement.db[i].element()) { if (ytcenter.classManagement.db[i].element().tagName === tagname && ytcenter.classManagement.db[i].condition(url)) a.push(ytcenter.classManagement.db[i].className); } else { //con.warn("[Element Class Management] Element does not exist!", ytcenter.classManagement.db[i]); } } return a.join(" "); }; ytcenter.classManagement.updateClassesByGroup = function(groups, url) { function isGroup(a, b) { var i, j; if (a.length === 1 && b.length === 1) { return a[0] === b[0]; } else if (a.length === 1 && b.length > 1) { for (i = 0; i < b.length; i++) { if (a[0] === b[i]) { return true; } } } else if (a.length > 1 && b.length === 1) { for (i = 0; i < a.length; i++) { if (a[i] === b[0]) { return true; } } } else if (a.length > 1 && b.length > 1) { for (i = 0; i < a.length; i++) { for (j = 0; j < b.length; j++) { if (a[i] === b[j]) { return true; } } } } return false; } var i, j, k, elm = null; if (ytcenter.page === "embed") return; url = url || ytcenter.utils.getURL(url); if (!ytcenter.utils.isArray(groups)) { groups = [groups]; } for (i = 0; i < ytcenter.classManagement.db.length; i++) { if (isGroup(groups, ytcenter.classManagement.db[i].groups)) { elm = ytcenter.classManagement.db[i].element(); if (elm) { if (ytcenter.classManagement.db[i].condition(url)) { ytcenter.utils.addClass(elm, ytcenter.classManagement.db[i].className); } else { ytcenter.utils.removeClass(elm, ytcenter.classManagement.db[i].className); } } } } }; ytcenter.classManagement.db = [ {element: function(){return document.getElementById("page");}, className: "watch-stage-mode", condition: function(){return false;}, groups: ["init", "page", "page-center"]}, // We have our own theatre mode {element: function(){return document.getElementById("player");}, className: "", condition: function(loc){ if (ytcenter.settings.removeBrandingBackground) { var p = document.getElementById("player"); p.style.backgroundImage = ""; p.style.backgroundColor = ""; } return false; }, groups: ["player-branding"]}, {element: function(){return document.getElementById("page");}, className: "", condition: function(loc){ document.getElementById("page").style.setProperty("padding-left", ""); }, groups: ["page-center", "page"]}, {element: function(){return document.body;}, className: "white", condition: function(loc){ var p = ytcenter.getPage(); if (p === "watch") { return ytcenter.html5 && ytcenter.settings.playerColor === "white"; } else if (p === "embed") { return ytcenter.html5 && ytcenter.settings.embed_playerColor === "white"; } else if (p === "channel") { return ytcenter.html5 && ytcenter.settings.channel_playerColor === "white"; } return false; }, groups: ["player-color"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.likeButtonColor); ytcenter.utils.tintImage(ytcenter.icon.likebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-likebutton-color", "#watch-like:not(.yt-uix-button-toggled) .yt-uix-button-icon-watch-like { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-like:not(.yt-uix-button-toggled) .yt-uix-button-content { color: " + ytcenter.settings.likeButtonColor + "!important; }"); }); }, groups: ["likebuttoncolor", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.dislikeButtonColor); ytcenter.utils.tintImage(ytcenter.icon.dislikebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-color", "#watch-dislike:not(.yt-uix-button-toggled) .yt-uix-button-icon-watch-dislike { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-dislike:not(.yt-uix-button-toggled) .yt-uix-button-content { color: " + ytcenter.settings.dislikeButtonColor + "!important; }"); }); }, groups: ["dislikebuttoncolor", "page"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.likeButtonHoverColor); ytcenter.utils.tintImage(ytcenter.icon.likebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-likebutton-hover-color", "#watch-like:not(.yt-uix-button-toggled):hover .yt-uix-button-icon-watch-like { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-like:not(.yt-uix-button-toggled):hover .yt-uix-button-content { color: " + ytcenter.settings.likeButtonHoverColor + "!important; }"); }); }, groups: ["likebuttonhovercolor", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.dislikeButtonHoverColor); ytcenter.utils.tintImage(ytcenter.icon.dislikebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-hover-color", "#watch-dislike:not(.yt-uix-button-toggled):hover .yt-uix-button-icon-watch-dislike { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-dislike:not(.yt-uix-button-toggled):hover .yt-uix-button-content { color: " + ytcenter.settings.dislikeButtonHoverColor + "!important; }"); }); }, groups: ["dislikebuttonhovercolor", "page"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.likedButtonColor); ytcenter.utils.tintImage(ytcenter.icon.likebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-likedbutton-color", "#watch-like.yt-uix-button-toggled .yt-uix-button-icon-watch-like { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-like.yt-uix-button-toggled .yt-uix-button-content { color: " + ytcenter.settings.likedButtonColor + "!important; }"); }); }, groups: ["likedbuttoncolor", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.dislikedButtonColor); ytcenter.utils.tintImage(ytcenter.icon.dislikebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-dislikedbutton-color", "#watch-dislike.yt-uix-button-toggled .yt-uix-button-icon-watch-dislike { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-dislike.yt-uix-button-toggled .yt-uix-button-content { color: " + ytcenter.settings.dislikedButtonColor + "!important; }"); }); }, groups: ["dislikedbuttoncolor", "page"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.likedButtonHoverColor); ytcenter.utils.tintImage(ytcenter.icon.likebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-likedbutton-hover-color", "#watch-like.yt-uix-button-toggled:hover .yt-uix-button-icon-watch-like { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-like.yt-uix-button-toggled:hover .yt-uix-button-content { color: " + ytcenter.settings.likedButtonHoverColor + "!important; }"); }); }, groups: ["likedbuttonhovercolor", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var color = ytcenter.utils.hexToColor(ytcenter.settings.dislikedButtonHoverColor); ytcenter.utils.tintImage(ytcenter.icon.dislikebuttonicon, { r: color.red, g: color.green, b: color.blue, a: 1 }, function(canvas){ ytcenter.utils.setCustomCSS("ytcenter-dislikedbutton-hover-color", "#watch-dislike.yt-uix-button-toggled:hover .yt-uix-button-icon-watch-dislike { background: url(" + canvas.toDataURL("image/png") + ") no-repeat!important; } #watch-dislike.yt-uix-button-toggled:hover .yt-uix-button-content { color: " + ytcenter.settings.dislikedButtonHoverColor + "!important; }"); }); }, groups: ["dislikedbuttonhovercolor", "page"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var opacity = ytcenter.settings.likeButtonOpacity; var opacityHover = ytcenter.settings.likeButtonHoverOpacity; var filter = "none"; var filterHover = "none"; if (opacity < 100 && opacity >= 0) { filter = "alpha(opacity=" + opacity + ")"; } if (opacityHover < 100 && opacityHover >= 0) { filterHover = "alpha(opacity=" + opacityHover + ")"; } ytcenter.utils.setCustomCSS("ytcenter-likebutton-opacity", "#watch-like:not(.yt-uix-button-toggled) { opacity: " + (opacity/100) + "; filter: " + filter + "; }"); ytcenter.utils.setCustomCSS("ytcenter-likebutton-hover-opacity", "#watch-like:not(.yt-uix-button-toggled):hover { opacity: " + (opacityHover/100) + "; filter: " + filterHover + "; }"); }, groups: ["likebuttonopacity", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var opacity = ytcenter.settings.dislikeButtonOpacity; var opacityHover = ytcenter.settings.dislikeButtonHoverOpacity; var filter = "none"; var filterHover = "none"; if (opacity < 100 && opacity >= 0) { filter = "alpha(opacity=" + opacity + ")"; } if (opacityHover < 100 && opacityHover >= 0) { filterHover = "alpha(opacity=" + opacityHover + ")"; } ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-opacity", "#watch-dislike:not(.yt-uix-button-toggled) { opacity: " + (opacity/100) + "; filter: " + filter + "; }"); ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-hover-opacity", "#watch-dislike:not(.yt-uix-button-toggled):hover { opacity: " + (opacityHover/100) + "; filter: " + filterHover + "; }"); }, groups: ["dislikebuttonopacity", "page"]}, {element: function(){return document.getElementById("watch-like");}, className: "", condition: function(loc){ var opacity = ytcenter.settings.likedButtonOpacity; var opacityHover = ytcenter.settings.likedButtonHoverOpacity; var filter = "none"; var filterHover = "none"; if (opacity < 100 && opacity >= 0) { filter = "alpha(opacity=" + opacity + ")"; } if (opacityHover < 100 && opacityHover >= 0) { filterHover = "alpha(opacity=" + opacityHover + ")"; } ytcenter.utils.setCustomCSS("ytcenter-likebutton-opacity", "#watch-like:.yt-uix-button-toggled { opacity: " + (opacity/100) + "; filter: " + filter + "; }"); ytcenter.utils.setCustomCSS("ytcenter-likebutton-hover-opacity", "#watch-like:.yt-uix-button-toggled:hover { opacity: " + (opacityHover/100) + "; filter: " + filterHover + "; }"); }, groups: ["likedbuttonopacity", "page"]}, {element: function(){return document.getElementById("watch-dislike");}, className: "", condition: function(loc){ var opacity = ytcenter.settings.dislikedButtonOpacity; var opacityHover = ytcenter.settings.dislikedButtonHoverOpacity; var filter = "none"; var filterHover = "none"; if (opacity < 100 && opacity >= 0) { filter = "alpha(opacity=" + opacity + ")"; } if (opacityHover < 100 && opacityHover >= 0) { filterHover = "alpha(opacity=" + opacityHover + ")"; } ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-opacity", "#watch-dislike.yt-uix-button-toggled { opacity: " + (opacity/100) + "; filter: " + filter + "; }"); ytcenter.utils.setCustomCSS("ytcenter-dislikebutton-hover-opacity", "#watch-dislike.yt-uix-button-toggled:hover { opacity: " + (opacityHover/100) + "; filter: " + filterHover + "; }"); }, groups: ["dislikedbuttonopacity", "page"]}, {element: function(){return document.body;}, className: "ytcenter-player-darkside-bg", condition: function(loc){ return ytcenter.player.darkside(); }, groups: ["darkside", "page"]}, {groups: ["hide-recommended-channels"], element: function(){return document.body;}, className: "ytcenter-hide-recommended-channels", condition: function(loc){return ytcenter.settings.hideRecommendedChannels;}}, {groups: ["hide-feed-item-action-menu"], element: function(){return document.body;}, className: "ytcenter-hide-feed-item-action-menu", condition: function(loc){return ytcenter.settings.disableFeedItemActionMenu;}}, {groups: ["hide-guide-count"], element: function(){return document.body;}, className: "ytcenter-hide-guide-count", condition: function(loc){return ytcenter.settings.disableGuideCount;}}, {groups: ["darkside"], element: function(){return document.body;}, className: "ytcenter-player-darkside-bg-retro", condition: function(loc){return (ytcenter.getPage() === "watch" && ytcenter.player.getCurrentPlayerSize().large && ytcenter.settings.playerDarkSideBG && ytcenter.settings.playerDarkSideBGRetro);}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-pos-topleft", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterPosition === "topleft";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-pos-topright", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterPosition === "topright";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-pos-bottomleft", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterPosition === "bottomleft";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-pos-bottomright", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterPosition === "bottomright";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-visible-always", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterVisible === "always";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-visible-show_hover", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterVisible === "show_hover";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-visible-hide_hover", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterVisible === "hide_hover";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-watchlater-visible-never", condition: function(loc){return ytcenter.settings.videoThumbnailWatchLaterVisible === "never";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-pos-topleft", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodePosition === "topleft";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-pos-topright", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodePosition === "topright";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-pos-bottomleft", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodePosition === "bottomleft";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-pos-bottomright", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodePosition === "bottomright";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-visible-always", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodeVisible === "always";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-visible-show_hover", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodeVisible === "show_hover";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-visible-hide_hover", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodeVisible === "hide_hover";}}, {groups: ["thumbnail"], element: function(){return document.body;}, className: "ytcenter-thumbnail-timecode-visible-never", condition: function(loc){return ytcenter.settings.videoThumbnailTimeCodeVisible === "never";}}, {groups: ["hide-ticker", "page"], element: function(){return document.body;}, className: "ytcenter-ticker-hidden", condition: function(loc){ if (ytcenter.settings["hideTicker"]) { ytcenter.utils.removeClass("sitewide-ticker-visible", document.body); return true; } else { return false; } }}, {groups: ["hide-lang", "page"], element: function(){return document.body;}, className: "hide-lang-alert", condition: function(loc){ return ytcenter.settings["hideLangAlert"]; }}, {groups: ["player-endscreen"], element: function(){return document.body;}, className: "ytcenter-disable-endscreen", condition: function(loc){return loc.pathname === "/watch" && ytcenter.settings["removeRelatedVideosEndscreen"];}}, {groups: ["lightsoff"], element: function(){return document.body;}, className: "ytcenter-lights-off-click-through", condition: function(loc){return ytcenter.settings["lightbulbClickThrough"];}}, {groups: ["hide-watched-videos", "page"], element: function(){return document.body;}, className: "ytcenter-hide-watched-videos", condition: function(loc){return ytcenter.gridview.isEnabled() && loc.pathname.indexOf("/feed/watch_later") !== 0 && ytcenter.settings.hideWatchedVideos;}}, {groups: ["gridview", "page"], element: function(){return document.body;}, className: "ytcenter-gridview", condition: function(loc){return ytcenter.gridview.isEnabled();}}, {groups: ["flex"], element: function(){return document.getElementById("page");}, className: "no-flex", condition: function(loc){return !ytcenter.settings.flexWidthOnPage && loc.pathname !== "/watch";}}, {groups: ["lightsoff"], element: function(){return document.body;}, className: "ytcenter-lights-off", condition: function(loc){return ytcenter.player.isLightOff;}}, {groups: ["ads"], element: function(){return document.getElementById("watch-video-extra");}, className: "hid", condition: function(loc){return ytcenter.settings.removeAdvertisements;}}, {groups: ["flex", "page"], element: function(){return document.body;}, className: "flex-width-enabled", condition: function(loc){var p = ytcenter.getPage();return ((ytcenter.settings.flexWidthOnPage && loc.pathname !== "/watch" && p !== "channel") || (ytcenter.settings.flexWidthOnChannelPage && p === "channel"))}}, {groups: ["player-branding"], element: function(){return document.body;}, className: "ytcenter-branding-remove-banner", condition: function(loc){return ytcenter.settings.removeBrandingBanner;}}, {groups: ["player-branding"], element: function(){return document.body;}, className: "ytcenter-branding-remove-background", condition: function(loc){return ytcenter.settings.removeBrandingBackground;}}, {groups: ["ads"], element: function(){return document.body;}, className: "ytcenter-remove-ads-page", condition: function(loc){return ytcenter.settings.removeAdvertisements;}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-not-watch", condition: function(loc){return loc.pathname !== "/watch";}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-search", condition: function(loc){return loc.pathname === "/results";}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-watch", condition: function(loc){return loc.pathname === "/watch";}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-home", condition: function(loc){return loc.pathname === "/";}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-feed", condition: function(loc){return loc.pathname.indexOf("/feed/") === 0 || loc.pathname === "/";}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-subscriptions", condition: function(loc){return loc.pathname.indexOf("/feed/subscriptions") === 0;}}, {groups: ["page"], element: function(){return document.body;}, className: "ytcenter-site-channel", condition: function(){return ytcenter.getPage() === "channel";}}, {groups: ["header", "page"], element: function(){return document.body;}, className: "static-header", condition: function(){return ytcenter.settings.staticHeader;}}, {groups: ["player-resize", "page"], element: function(){return document.body;}, className: "ytcenter-non-resize", condition: function(loc){return loc.pathname === "/watch" && !ytcenter.settings.enableResize;}} ]; ytcenter.intelligentFeed = (function(){ var exports = {}, observer, config = { attributes: true }, feed; ytcenter.unload(function(){ if (observer) { observer.disconnect(); observer = null; } }); exports.getFeeds = function(){ return document.getElementsByClassName("feed-item-main"); }; exports.getItems = function(feed){ return feed.getElementsByClassName("yt-uix-shelfslider-item"); }; exports.getShelfWrappers = function(feed){ return feed.getElementsByClassName("shelf-wrapper"); }; exports.getShelves = function(feed){ return feed.getElementsByClassName("yt-uix-shelfslider-list"); }; exports.getFeedCollapsedContainer = function(feed){ return feed.getElementsByClassName("feed-item-collapsed-container"); }; exports.getCollapsedItems = function(feed){ return feed.getElementsByClassName("feed-item-collapsed-items"); }; exports.getShowMoreButton = function(feed){ var a = feed.getElementsByClassName("feed-item-expander-button"); if (a && a.length > 0 && a[0]) return a[0]; return null; }; exports.setup = function(){ exports.dispose(); con.log("[Intelligent Feeds] Setting up!"); var shelf, items, i, j, shelfWrappers, collapsedItem, feedCollapsedContainer, showMoreButton; feed = exports.getFeeds(); for (i = 0; i < feed.length; i++) { items = exports.getItems(feed[i]); shelf = exports.getShelves(feed[i]); shelfWrappers = exports.getShelfWrappers(feed[i]); collapsedItem = exports.getCollapsedItems(feed[i]); feedCollapsedContainer = exports.getFeedCollapsedContainer(feed[i]); showMoreButton = exports.getShowMoreButton(feed[i]); if (items && items.length > 0 && shelf && shelf.length > 0 && shelf[0] && shelfWrappers && shelfWrappers.length > 0 && feedCollapsedContainer && feedCollapsedContainer.length > 0 && feedCollapsedContainer[0]) { ytcenter.utils.addClass(feed[i], "ytcenter-intelligentfeed ytcenter-intelligentfeed-minimized"); con.log("[Intelligent Feeds] There are " + items.length + " items and " + shelf.length + " shelves!"); shelf = shelf[0]; for (j = 0; j < items.length; j++) { shelf.appendChild(items[j]); } if (showMoreButton) { showMoreButton.setAttribute("data-original-textContent", showMoreButton.textContent); showMoreButton.textContent = showMoreButton.textContent.replace(/( [0-9]+)|([0-9]+ )|([0-9]+)/, ""); } observer = ytcenter.mutation.observe(feedCollapsedContainer[0], config, function(mutations){ mutations.forEach(function(mutation){ if (mutation.type === "attributes" && mutation.attributeName === "class") { if (ytcenter.utils.hasClass(mutation.target, "expanded")) { ytcenter.utils.removeClass(mutation.target.parentNode.parentNode, "ytcenter-intelligentfeed-minimized"); } else if (ytcenter.utils.hasClass(mutation.target, "collapsed")) { ytcenter.utils.addClass(mutation.target.parentNode.parentNode, "ytcenter-intelligentfeed-minimized"); } } }); }); } } }; exports.dispose = function(){ if (observer) observer.disconnect(); observer = null; if (feed) { var shelves, items, i, j, k, frag, _items, showMoreButton; for (i = 0; i < feed.length; i++) { if (ytcenter.utils.hasClass(feed[i], "ytcenter-intelligentfeed")) { shelves = exports.getShelves(feed[i]); items = exports.getItems(feed[i]); showMoreButton = exports.getShowMoreButton(feed[i]); frag = []; _items = []; con.log("[Intelligent Feeds] Reordering " + items.length + " items to " + shelves.length + " shelves!"); for (j = 0; j < items.length; j++) { var n = Math.floor(j/(items.length/shelves.length)); if (!_items[n]) _items[n] = []; _items[n].push(items[j]); } for (j = 0; j < _items.length; j++) { for (k = 0; k < _items[j].length; k++) { shelves[j].appendChild(_items[j][k]); } } if (showMoreButton) { showMoreButton.textContent = showMoreButton.getAttribute("data-original-textContent"); showMoreButton.removeAttribute("data-original-textContent"); } ytcenter.utils.removeClass(feed[i], "ytcenter-intelligentfeed ytcenter-intelligentfeed-minimized"); } } } }; return exports; })(); ytcenter.guideMode = (function(){ function clickListener() { clicked = true; } function updateGuide() { if (ytcenter.getPage() !== "watch") return; if (ytcenter.settings.guideMode === "always_open") { ytcenter.utils.removeClass(document.getElementById("guide-main"), "collapsed"); document.getElementById("guide-main").children[1].style.display = "block"; document.getElementById("guide-main").children[1].style.height = "auto"; } else if (ytcenter.settings.guideMode === "always_closed") { ytcenter.utils.addClass(document.getElementById("guide-main"), "collapsed"); document.getElementById("guide-main").children[1].style.display = "none"; document.getElementById("guide-main").children[1].style.height = "auto"; } } var timer, observer, observer2, clicked = false, main_guide, guide_container, guideToggle, config = { attributes: true, attributeOldValue: true }, confi2 = { childList: true, subtree: true }; ytcenter.unload(function(){ if (observer) { observer.disconnect(); observer = null; } if (observer2) { observer2.disconnect(); observer2 = null; } }); return { setup: function(){ con.log("[Guide] Configurating the state updater!"); if (observer) { observer.disconnect(); observer = null; } if (observer2) { observer2.disconnect(); observer2 = null; } guideToggle = document.getElementsByClassName("guide-module-toggle")[0]; if (guideToggle) ytcenter.utils.removeEventListener(guideToggle, "click", clickListener, false); if (ytcenter.settings.guideMode !== "default") { if (document.getElementById("guide")) { observer2 = ytcenter.mutation.observe(document.getElementById("guide"), confi2, function(mutations){ mutations.forEach(function(mutation){ if (ytcenter.utils.inArray(mutation.removedNodes, guide_container)) { con.log("[Guide] Main Guide has been removed"); main_guide = document.getElementById("guide-main"); guide_container = document.getElementById("guide-container"); if (main_guide) { if (observer) observer.disconnect(); observer = ytcenter.mutation.observe(main_guide, config, function(mutations){ mutations.forEach(function(mutation){ if (mutation.type === "attributes" && mutation.attributeName === "class" && ((mutation.oldValue.indexOf("collapsed") !== -1) !== (mutation.target.className.indexOf("collapsed") !== -1))) { con.log("[Guide] Mutations...", mutation.oldValue.indexOf("collapsed") !== -1, mutation.target.className.indexOf("collapsed") !== -1, ytcenter.settings.guideMode); if (mutation.oldValue.indexOf("collapsed") === -1 && ytcenter.settings.guideMode === "always_closed") return; if (mutation.oldValue.indexOf("collapsed") !== -1 && ytcenter.settings.guideMode === "always_open") return; con.log("[Guide] Updating State!"); uw.clearTimeout(timer); if (clicked) { clicked = false; return; } timer = uw.setTimeout(function(){ updateGuide(); }, 500); } }); }); } if (guideToggle) ytcenter.utils.removeEventListener(guideToggle, "click", clickListener, false); guideToggle = document.getElementsByClassName("guide-module-toggle")[0]; if (guideToggle) ytcenter.utils.addEventListener(guideToggle, "click", clickListener, false); if (clicked) { clicked = false; return; } updateGuide(); } else { con.log("[Guide] Main Guide is still intact"); } }); }); } main_guide = document.getElementById("guide-main"); guide_container = document.getElementById("guide-container"); if (main_guide) { ytcenter.mutation.observe(main_guide, config, function(mutations){ mutations.forEach(function(mutation){ if (mutation.type === "attributes" && mutation.attributeName === "class" && ((mutation.oldValue.indexOf("collapsed") !== -1) !== (mutation.target.className.indexOf("collapsed") !== -1))) { con.log("[Guide] Mutations...", mutation.oldValue.indexOf("collapsed") !== -1, mutation.target.className.indexOf("collapsed") !== -1, ytcenter.settings.guideMode); if (mutation.oldValue.indexOf("collapsed") === -1 && ytcenter.settings.guideMode === "always_closed") return; if (mutation.oldValue.indexOf("collapsed") !== -1 && ytcenter.settings.guideMode === "always_open") return; con.log("[Guide] Updating State!"); uw.clearTimeout(timer); if (clicked) { clicked = false; return; } timer = uw.setTimeout(function(){ updateGuide(); }, 500); } }); }); } if (guideToggle) ytcenter.utils.addEventListener(guideToggle, "click", clickListener, false); } updateGuide(); } }; })(); ytcenter.events.addEvent("ui-refresh", function(){ if (ytcenter.settings.removeBrandingBanner) { ytcenter.utils.addClass(document.body, "ytcenter-branding-remove-banner"); } else { ytcenter.utils.removeClass(document.body, "ytcenter-branding-remove-banner"); } if (ytcenter.settings.removeBrandingBackground) { ytcenter.utils.addClass(document.body, "ytcenter-branding-remove-background"); } else { ytcenter.utils.removeClass(document.body, "ytcenter-branding-remove-background"); } ytcenter.classManagement.updateClassesByGroup(["player-branding"]); }); ytcenter.cssElements = {}; ytcenter.unsafeInit = function(){ // Settings made public ytcenter.unsafe.injected = injected; ytcenter.unsafe.settings = ytcenter.unsafe.settings || {}; ytcenter.unsafe.getDebug = ytcenter.utils.oldBind(function(){ return ytcenter.getDebug(); }, ytcenter.unsafe); ytcenter.unsafe.updateSignatureDecipher = ytcenter.utils.oldBind(function(){ uw.postMessage("YouTubeCenter" + JSON.stringify({ type: "updateSignatureDecipher" }), (loc.href.indexOf("http://") === 0 ? "http://www.youtube.com" : "https://www.youtube.com")); }, ytcenter.unsafe); ytcenter.unsafe.settings.setOption = ytcenter.utils.oldBind(function(key, value){ ytcenter.settings[key] = value; ytcenter.events.performEvent("settings-update"); uw.postMessage("YouTubeCenter" + JSON.stringify({ type: "saveSettings" }), (loc.href.indexOf("http://") === 0 ? "http://www.youtube.com" : "https://www.youtube.com")); }, ytcenter.unsafe.settings); ytcenter.unsafe.settings.getOption = ytcenter.utils.oldBind(function(key){ return ytcenter.settings[key]; }, ytcenter.unsafe.settings); ytcenter.unsafe.settings.getOptions = ytcenter.utils.oldBind(function(){ return ytcenter.settings; }, ytcenter.unsafe.settings); ytcenter.unsafe.settings.removeOption = ytcenter.utils.oldBind(function(key){ delete ytcenter.settings[key]; ytcenter.events.performEvent("settings-update"); uw.postMessage("YouTubeCenter" + JSON.stringify({ type: "saveSettings" }), (loc.href.indexOf("http://") === 0 ? "http://www.youtube.com" : "https://www.youtube.com")); }, ytcenter.unsafe.settings); ytcenter.unsafe.settings.listOptions = ytcenter.utils.oldBind(function(){ var keys = []; for (var key in ytcenter.settings) { if (ytcenter.settings.hasOwnProperty(key)) keys.push(key); } return keys; }, ytcenter.unsafe.settings); ytcenter.unsafe.settings.reload = ytcenter.utils.oldBind(function(){ uw.postMessage("YouTubeCenter" + JSON.stringify({ type: "loadSettings" }), (loc.href.indexOf("http://") === 0 ? "http://www.youtube.com" : "https://www.youtube.com")); }, ytcenter.unsafe.settings); ytcenter.utils.addEventListener(uw, "message", function(e){ if (e.origin !== "http://www.youtube.com" && e.origin !== "https://www.youtube.com") 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("YouTubeCenter") !== 0) return; // Checking if the token is present at the start of the string var d = JSON.parse(e.data.substring(13)); if (d.type === "saveSettings") { ytcenter.saveSettings(); } else if (d.type === "loadSettings") { ytcenter.loadSettings(); } else if (d.type === "updateSignatureDecipher") { ytcenter.utils.updateSignatureDecipher(); } if (typeof d.callback === "function") { var n = d.callback.split("."), a = uw, i; for (i = 0; o < n.length; i++) { a = a[n[i]]; } a(); } }, false); }; ytcenter._config_registered = false; (function(){ // Hijacks the ytplayer global variable. try { if (uw.ytplayer && uw.ytplayer.config) { ytcenter._config_registered = true; con.log("[Player Config Global] Player configuration already registered by YouTube."); if (uw.ytplayer.config.html5) { con.log("[Player] HTML5 configuration detected"); } // Make sure that modify config is applied to the player configuration. ytcenter.player.setConfig(ytcenter.utils.mergeObjects(uw.ytplayer.config || {}, ytcenter.player.config || {})); } if (uw.ytplayer && uw.ytplayer.config && uw.ytplayer.config.loaded) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.ytplayer.config)); ytcenter.player.disablePlayerUpdate = false; } else if (uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG && uw.yt.config_.PLAYER_CONFIG.loaded) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.yt.config_.PLAYER_CONFIG)); ytcenter.player.disablePlayerUpdate = false; } if (uw.ytplayer && uw.ytplayer.config && uw.ytplayer.config.args) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.ytplayer.config)); ytcenter.player.disablePlayerUpdate = false; } else if (uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG && uw.yt.config_.PLAYER_CONFIG.args) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.yt.config_.PLAYER_CONFIG)); ytcenter.player.disablePlayerUpdate = false; } if (ytcenter.utils.setterGetterClassCompatible()) { ytcenter.player.disablePlayerUpdate = false; uw.ytplayer = new PlayerConfig(function(config){ con.log("[External] Setting player configruation."); if (config) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), config)); if (ytcenter.player.config.html5) ytcenter.player.disablePlayerUpdate = true; } else { ytcenter.player.setConfig(config); } }, function(){ if (ytcenter.feather) { ytcenter.player.config = ytcenter.player.modifyConfig("watch", ytcenter.player.getRawPlayerConfig()); } return ytcenter.player.config; }); } else { con.log("[PlayerConfig Hijacker] Setter Getter Method not suppoted!"); if (uw.ytplayer && uw.ytplayer.config) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.ytplayer.config)); } else if (uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG) { ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.yt.config_.PLAYER_CONFIG)); } ytcenter.player.disablePlayerUpdate = false; } } catch (e) { con.error(e); if (uw && uw.ytplayer && uw.ytplayer.config) ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.ytplayer.config)); else if (uw.yt && uw.yt.config_ && uw.yt.config_.PLAYER_CONFIG) ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), uw.yt.config_.PLAYER_CONFIG)); ytcenter.player.disablePlayerUpdate = false; } ytcenter.pageReadinessListener.waitfor = function(){ return ytcenter.__settingsLoaded; }; ytcenter.pageReadinessListener.addEventListener("headerInitialized", function(page){ if (ytcenter.settings.useSecureProtocol && page !== "comments") { if (loc.href.indexOf("http://") === 0) { loc.replace(loc.href.replace(/^http/, "https")); return; } } ytcenter.spf.setEnabled(ytcenter.settings.ytspf); ytcenter.unsafeInit(); ytcenter.language.update(); /* We don't want to add everything. So only the neccessary stuff is added. */ if (page === "comments") { ytcenter.cssElements.flags = ytcenter.utils.addCSS("flags", ytcenter.css.flags); return; } if (page === "embed" && !ytcenter.settings.embed_enabled) { ytcenter.embed._writeEmbed(); return; } if (page === "embed" && ytcenter.utils.inArray(loc.search.substring(1).split("&"), "autoplay=1")) { loc.search = loc.search.replace("autoplay=1", "ytcenter-autoplay=1"); } if (page === "watch" && document && document.head && document.head.getElementsByTagName) { var links = document.head.getElementsByTagName("link"); if (links && links.length > 0 && links[0] && links[0].className && links[0].className.indexOf("www-feather") === 0) { con.log("[Feather] Feather layout detected!"); ytcenter.feather = true; } } if (ytcenter.feather) { /*var obj = uw && uw.yt || {}, pobj = uw && uw.yt && uw.yt.player || {}, app = ytcenter.utils.oldBind(function(id, config){ ytcenter.player.setConfig(ytcenter.player.modifyConfig("watch", config)); return oApp(id, ytcenter.player.getConfig()); }), oApp = uw && uw.yt && uw.yt.player && uw.yt.player.Application || null; defineLockedProperty(pobj, "Application", ytcenter.utils.oldBind(function(o){ con.log("[Feather] Setting Application."); oApp = o; }), ytcenter.utils.oldBind(function(){ con.log("[Feather] Application has been requested."); return app; })); defineLockedProperty(obj, "player", ytcenter.utils.oldBind(function(o){ var key; for (key in o) { if (o.hasOwnProperty(key)) { pobj[key] = o[key]; } } }), ytcenter.utils.oldBind(function(){ return pobj; })); defineLockedProperty(uw, "yt", ytcenter.utils.oldBind(function(o){ var key; for (key in o) { if (o.hasOwnProperty(key)) { obj[key] = o[key]; } } }), ytcenter.utils.oldBind(function(){ return obj; }));*/ ytcenter.cssElements.feather = ytcenter.utils.addCSS("feather", ytcenter.css.feather); } if (ytcenter.getPage() !== "embed") { ytcenter.cssElements.general = ytcenter.utils.addCSS("general", ytcenter.css.general); ytcenter.cssElements.flags = ytcenter.utils.addCSS("flags", ytcenter.css.flags); ytcenter.cssElements.html5player = ytcenter.utils.addCSS("html5player", ytcenter.css.html5player); ytcenter.cssElements.gridview = ytcenter.utils.addCSS("gridview", ytcenter.css.gridview); ytcenter.cssElements.images = ytcenter.utils.addCSS("images", ytcenter.css.images); ytcenter.cssElements.dialog = ytcenter.utils.addCSS("dialog", ytcenter.css.dialog); ytcenter.cssElements.scrollbar = ytcenter.utils.addCSS("scrollbar", ytcenter.css.scrollbar); ytcenter.cssElements.list = ytcenter.utils.addCSS("list", ytcenter.css.list); ytcenter.cssElements.confirmbox = ytcenter.utils.addCSS("confirmbox", ytcenter.css.confirmbox); ytcenter.cssElements.panel = ytcenter.utils.addCSS("panel", ytcenter.css.panel); ytcenter.cssElements.resize = ytcenter.utils.addCSS("resize", ytcenter.css.resize, ytcenter.settings.enableResize); ytcenter.cssElements.resizePanel = ytcenter.utils.addCSS("resizePanel", ytcenter.css.resizePanel); ytcenter.cssElements.modules = ytcenter.utils.addCSS("modules", ytcenter.css.modules); ytcenter.cssElements.settings = ytcenter.utils.addCSS("settings", ytcenter.css.settings); //ytcenter.cssElements.centering = ytcenter.utils.addCSS("centering", ytcenter.css.centering, false); ytcenter.cssElements.topbar = ytcenter.utils.addCSS("topbar", ytcenter.css.topbar); ytcenter.cssElements.player = ytcenter.utils.addCSS("player", ytcenter.css.player); ytcenter.cssElements.darkside = ytcenter.utils.addCSS("darkside", ytcenter.css.darkside); ytcenter.cssElements.elementFocus = ytcenter.utils.addCSS("element-focus", ytcenter.css.elementFocus, false); //ytcenter.cssElements.yonez = ytcenter.utils.addCSS("yonez", ytcenter.css.yonez, ytcenter.settings.yonezCleanYT); try { ytcenter.unsafe.openSettings = ytcenter.utils.oldBind(function(){ if (!ytcenter.settingsPanelDialog) ytcenter.settingsPanelDialog = ytcenter.settingsPanel.createDialog(); ytcenter.settingsPanelDialog.setVisibility(true); }); ytcenter.unsafeCall("GM_registerMenuCommand", [ytcenter.language.getLocale("BUTTON_SETTINGS_LABEL")], ytcenter.unsafe.openSettings); /*if (typeof GM_registerMenuCommand === "function") { GM_registerMenuCommand(ytcenter.language.getLocale("BUTTON_SETTINGS_LABEL"), ytcenter.unsafe.openSettings); }*/ } catch (e) { con.error(e); } } else { ytcenter.cssElements.embed = ytcenter.utils.addCSS("embed", ytcenter.css.embed); } /*****START OF SAVEAS AND BLOB IMPLEMENTATION*****/ /* Blob.js * A Blob implementation. * 2013-06-20 * * By Eli Grey, http://eligrey.com * By Devin Samarin, https://github.com/eboyjr * License: X11/MIT * See LICENSE.md */ /*http://purl.eligrey.com/github/Blob.js/blob/master/Blob.js*/ /* FileSaver.js * A saveAs() FileSaver implementation. * 2013-01-23 * * By Eli Grey, http://eligrey.com * License: X11/MIT * See LICENSE.md */ /*http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js*/ /* The reason this is obfuscated is because IE crashes when using IE7Pro to run YouTube Center. * I think that it has something to do with the javascript parser IE7Pro are using. * The source code of the injected obfuscated part can be found on: * https://github.com/YePpHa/YouTubeCenter/tree/master/obfuscated/io.js * ------ * Tool used: http://www.jsobfuscate.com/index.php * Encoding: Normal * Fast Decode: enabled * Special Characters disabled * --- * Result replaced \\ with \\\\ and " with \". */ ytcenter.inject("eval(function(p,a,c,k,e,d){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[function(e){return d[e]}];e=function(){return'\\\\w+'};c=1};while(c--){if(k[c]){p=p.replace(new RegExp('\\\\b'+e(c)+'\\\\b','g'),k[c])}}return p}('v=v||{};v.R=v.R||{};(4(I,v){o{v.R.B=B}q(e){}8(J B!==\"4\"||J k===\"2c\")8(J B===\"4\"&&J K!==\"2c\")I.k=K;j v.R.B=(4(6){\"1W 2l\";d Z=(4(){d a=t;o{a=6.Z||6.2d||6.1A||6.17}q(e){o{a=6.2d||6.1A||6.17}q(e){o{a=6.1A||6.17}q(e){o{a=6.17}q(e){}}}}f a})()||(4(6){d 1l=4(P){f 2P.S.1r.T(P).2Q(/^\\\\[P\\\\s(.*)\\\\]$/)[1]},1n=4 Z(){g.7=[]},A=4(7,c,w){g.7=7;g.1F=7.p;g.c=c;g.w=w},1f=1n.S,19=A.S,1d=6.1d,1s=4(c){g.1I=g[g.l=c]},1v=(\"2m 2V 22 2n 2W \"+\"31 30 2Z\").1M(\" \"),1h=1v.p,H=6.k||6.K||6,1k=H.11,1i=H.1u,k=H,1a=6.1a,1b=6.1b,1z=6.1z,Y=6.Y;A.2b=19.2b=14;1C(1h--){1s.S[1v[1h]]=1h+1}8(!H.11){k=6.k={}}k.11=4(b){d c=b.c,N;8(c===Q){c=\"2q/2z-2t\"}8(b 1c A){N=\"7:\"+c;8(b.w===\"1g\"){f N+\";1g,\"+b.7}j 8(b.w===\"2h\"){f N+\",\"+2i(b.7)}8(1a){f N+\";1g,\"+1a(b.7)}j{f N+\",\"+2o(b.7)}}j 8(1k){f 1k.T(H,b)}};k.1u=4(1m){8(1m.2D(0,5)!==\"7:\"&&1i){1i.T(H,1m)}};1f.1X=4(7){d E=g.7;8(Y&&(7 1c 1z||7 1c Y)){d 1q=\"\",1o=C Y(7),i=0,29=1o.p;20(;i<29;i++){1q+=2H.2M(1o[i])}E.x(1q)}j 8(1l(7)===\"B\"||1l(7)===\"2K\"){8(1d){d 2g=C 1d;E.x(2g.32(7))}j{2r C 1s(\"2n\")}}j 8(7 1c A){8(7.w===\"1g\"&&1b){E.x(1b(7.7))}j 8(7.w===\"2h\"){E.x(2i(7.7))}j 8(7.w===\"21\"){E.x(7.7)}}j{8(J 7!==\"2u\"){7+=\"\"}E.x(3r(2o(7)))}};1f.1U=4(c){8(!1w.p){c=Q}f C A(g.7.3i(\"\"),c,\"21\")};1f.1r=4(){f\"[P Z]\"};19.L=4(1Y,1T,c){d 1t=1w.p;8(1t<3){c=Q}f C A(g.7.L(1Y,1t>1?1T:g.7.p),c,g.w)};19.1r=4(){f\"[P B]\"};f 1n}(6));f 4(12,1x){d c=1x?(1x.c||\"\"):\"\";d 1y=C Z();8(12){20(d i=0,23=12.p;i<23;i++){1y.1X(12[i])}}f 1y.1U(c)}}(I));v.R.13=(I&&I.13)||(18&&18.1V&&18.1V.2B(18))||(4(6){\"1W 2l\";d 1B=6.3n,1p=4(){d a;o{a=6.k||6.K||6}q(e){o{a=6.k||6.K||6}q(e){o{a=6.K||6}q(e){o{a=6}q(e){}}}}f a},k=1p(),10=1B.3m(\"3k://3a.2I.3d/3e/3h\",\"a\"),2w=!6.3g&&\"V\"3b 10,1Q=4(2s){d n=1B.34(\"36\");n.37(\"1Q\",14,t,6,0,0,0,0,0,t,t,t,t,0,Q);2s.38(n)},16=6.3j,1E=6.3s||16||6.3p,2x=4(F){(6.3q||6.3l)(4(){2r F},0)},15=\"2q/2z-2t\",1H=0,M=[],2e=4(){d i=M.p;1C(i--){d r=M[i];8(J r===\"2u\"){k.1u(r)}j{r.26()}}M.p=0},1e=4(9,U,n){U=[].33(U);d i=U.p;1C(i--){d 1j=9[\"1L\"+U[i]];8(J 1j===\"4\"){o{1j.T(9,n||9)}q(F){2x(F)}}}},1G=4(b,l){d 9=g,c=b.c,1O=t,m,W,1P=4(){d m=1p().11(b);M.x(m);f m},1S=4(){1e(9,\"1Z 25 1K 24\".1M(\" \"))},y=4(){8(1O||!m){m=1P(b)}8(W){W.2p.1N=m}j{2O.2X(m,\"2S\")}9.u=9.G;1S()},z=4(2v){f 4(){8(9.u!==9.G){f 2v.2T(g,1w)}}},1R={2k:14,3c:t},L;9.u=9.2f;8(!l){l=\"V\"}8(2w){m=1P(b);10.1N=m;10.V=l;1Q(10);9.u=9.G;1S();f}8(6.2G&&c&&c!==15){L=b.L||b.2L;b=L.T(b,0,b.1F,15);1O=14}8(16&&l!==\"V\"){l+=\".V\"}8(c===15||16){W=6}8(!1E){y();f}1H+=b.1F;1E(6.2J,1H,z(4(2y){2y.2U.2N(\"3o\",1R,z(4(1J){d 1D=4(){1J.2j(l,1R,z(4(r){r.39(z(4(D){D.2a=4(n){W.2p.1N=r.3f();M.x(r);9.u=9.G;1e(9,\"24\",n)};D.27=4(){d X=D.X;8(X.1I!==X.22){y()}};\"1Z 25 1K O\".1M(\" \").35(4(n){D[\"1L\"+n]=9[\"1L\"+n]});D.1K(b);9.O=4(){D.O();9.u=9.G};9.u=9.28}),y)}),y)};1J.2j(l,{2k:t},z(4(r){r.26();1D()}),z(4(F){8(F.1I===F.2m){1D()}j{y()}}))}),y)}),y)},h=1G.S,13=4(b,l){f C 1G(b,l)};h.O=4(){d 9=g;9.u=9.G;1e(9,\"O\")};h.u=h.2f=0;h.28=1;h.G=2;h.X=h.2A=h.2C=h.2F=h.2E=h.27=h.2a=Q;6.2Y(\"2R\",2e,t);f 13}(I))})(I,v);',62,215,'||||function||view|data|if|filesaver||blob|type|var||return|this|FS_proto||else|URL|name|object_url|event|try|length|catch|file||false|readyState|ytcenter|encoding|push|fs_error|abortable|FakeBlob|Blob|new|writer|bb|ex|DONE|real_URL|self|typeof|webkitURL|slice|deletion_queue|data_URI_header|abort|object|null|io|prototype|call|event_types|download|target_view|error|Uint8Array|BlobBuilder|save_link|createObjectURL|blobParts|saveAs|true|force_saveable_type|webkit_req_fs|MSBlobBuilder|navigator|FB_proto|btoa|atob|instanceof|FileReaderSync|dispatch|FBB_proto|base64|file_ex_code|real_revoke_object_URL|listener|real_create_object_URL|get_class|object_URL|FakeBlobBuilder|buf|get_URL|str|toString|FileException|args|revokeObjectURL|file_ex_codes|arguments|options|builder|ArrayBuffer|MozBlobBuilder|doc|while|save|req_fs|size|FileSaver|fs_min_size|code|dir|write|on|split|href|blob_changed|get_object_url|click|create_if_not_found|dispatch_all|end|getBlob|msSaveOrOpenBlob|use|append|start|writestart|for|raw|ABORT_ERR|len|writeend|progress|remove|onerror|WRITING|buf_len|onwriteend|fake|undefined|WebKitBlobBuilder|process_deletion_queue|INIT|fr|URI|decodeURIComponent|getFile|create|strict|NOT_FOUND_ERR|NOT_READABLE_ERR|encodeURIComponent|location|application|throw|node|stream|string|func|can_use_save_link|throw_outside|fs|octet|onwritestart|bind|onprogress|substring|onabort|onwrite|chrome|String|w3|TEMPORARY|File|webkitSlice|fromCharCode|getDirectory|window|Object|match|unload|_blank|apply|root|SECURITY_ERR|ENCODING_ERR|open|addEventListener|SYNTAX_ERR|INVALID_STATE_ERR|NO_MODIFICATION_ALLOWED_ERR|readAsBinaryString|concat|createEvent|forEach|MouseEvents|initMouseEvent|dispatchEvent|createWriter|www|in|exclusive|org|1999|toURL|externalHost|xhtml|join|webkitRequestFileSystem|http|setTimeout|createElementNS|document|saved|mozRequestFileSystem|setImmediate|unescape|requestFileSystem'.split('|'),0,{}))"); /*****END OF SAVEAS AND BLOB IMPLEMENTATION*****/ }); ytcenter.pageReadinessListener.addEventListener("bodyInitialized", function(page){ if (ytcenter.feather) { var dir = document.body.getAttribute("dir"); ytcenter.utils.addClass(document.body, dir); ytcenter.ltr = (dir === "ltr"); /*** Add a separate section for this! ytcenter.utils.live.add("click", "button.yt-uix-button", function(e){ var el = null, i; for (i = 0; i < this.children.length; i++) { if (this.children[i].className.indexOf("yt-uix-button-menu") !== -1) { el = this.children[i]; break; } } });*/ } else if (!ytcenter.utils.hasClass(document.body, "ltr")) { ytcenter.ltr = false; } if (page === "comments") return; // We don't need to do anything here. if (page === "embed" && !ytcenter.settings.embed_enabled) return; ytcenter.mutation.observe(document.getElementById("page"), { attributes: true }, ytcenter.player._updateResize); if (ytcenter._config_registered) { // Re-creating the player to ensure that the correct fexp is applied correctly. if (uw && uw.yt && uw.yt.player && uw.yt.player.Application && typeof uw.yt.player.Application.create === "function") { ytcenter.player.setConfig(ytcenter.player.modifyConfig(page, ytcenter.player.getConfig())); uw.yt.player.Application.create("player-api", ytcenter.player.getConfig()); } } ytcenter.classManagement.applyClassesForElement(document.body); if (loc.href.indexOf(".youtube.com/embed/") === -1) { ytcenter.utils.live.add("click", "body.ytcenter-gridview #feed .feed-container button.feed-load-more", ytcenter.gridview.delayedUpdate); if (!ytcenter.welcome.hasBeenLaunched()) ytcenter.welcome.setVisibility(true); } ytcenter.updateLogoLink(); if (loc.pathname !== "/watch") ytcenter.player.turnLightOn(); else if (ytcenter.settings.lightbulbAutoOff) ytcenter.player.turnLightOff(); ytcenter.player.shortcuts(); if (document.getElementById("page") && ytcenter.utils.hasClass(document.getElementById("page"), "channel") && document.getElementById("content") && document.getElementById("content").children.length > 0 && ytcenter.utils.hasClass(document.getElementById("content").children[0], "branded-page-v2-container") && ytcenter.utils.hasClass(document.getElementById("content").children[0], "branded-page-v2-flex-width")) { document.body.className += " ytcenter-channelv2"; } }); ytcenter.pageSetup = function(){ var page = ytcenter.getPage(); ytcenter.channelPlaylistLinks.update(); if (page === "watch") { if (!ytcenter.settings.enableComments) { ytcenter.commentsLoader.setup(); } ytcenter.playlistAutoPlay.init(); ytcenter.effects.playerGlow.setOption("pixelInterval", ytcenter.settings.playerGlowPixelInterval); ytcenter.effects.playerGlow.setOption("factor", ytcenter.settings.playerGlowFactor); ytcenter.effects.playerGlow.setOption("glowEffectOnPlayer", ytcenter.settings.playerGlowEffectOnPlayer); ytcenter.effects.playerGlow.setOption("interval", (ytcenter.settings.playerGlowRequestAnimationFrame ? -1 : ytcenter.settings.playerGlowUpdateInterval)); ytcenter.effects.playerGlow.setOption("transition", ytcenter.settings.playerGlowTransition/1000); ytcenter.effects.playerGlow.setOption("blur", ytcenter.settings.playerGlowBlur); ytcenter.effects.playerGlow.setOption("spread", ytcenter.settings.playerGlowSpread); ytcenter.effects.playerGlow.setOption("opacity", ytcenter.settings.playerGlowOpacity/100); ytcenter.effects.playerGlow.setOption("multiglow", ytcenter.settings.playerMultiGlowEffect); ytcenter.effects.playerGlow.setOption("depth", ytcenter.settings.playerMultiGlowEffectDepth); ytcenter.effects.playerGlow.setOption("blockInterval", ytcenter.settings.playerMultiGlowEffectBlockInterval); ytcenter.effects.playerGlow.setEnabled(ytcenter.settings.playerGlowEnabled); var description = document.getElementById("action-panel-details"); var headline = document.getElementById("watch7-headline"); if (description && ytcenter.settings.expandDescription) { ytcenter.utils.removeClass(description, "yt-uix-expander-collapsed"); } if (headline && ytcenter.settings.headlineTitleExpanded) { ytcenter.utils.removeClass(headline, "yt-uix-expander-collapsed"); } } ytcenter.gridview.update(); if (page !== "embed") { ytcenter.title.init(); ytcenter.topScrollPlayer.setup(); ytcenter.topScrollPlayer.setEnabled(ytcenter.getPage() === "watch" && ytcenter.settings.topScrollPlayerEnabled); } var page_element = document.getElementById("page"); if (page_element && page === "watch" && ytcenter.settings.staticHeader_scrollToPlayer && ytcenter.settings.staticHeader) { ytcenter.utils.scrollTop(ytcenter.utils.getScrollPosition(page_element).y/2); } /* A simple Webkit hack, which will fix the horizontal scroll bar from appearing */ if (document.body.className.indexOf("webkit") !== -1) { var guideButton = document.getElementById("appbar-guide-button"), _timer = null; ytcenter.utils.addEventListener(guideButton, "click", function(){ function startTimer() { ytcenter.utils.cssFix(pageElm); _timer = uw.setInterval(function(){ if (count > 3) { stopTimer(); } ytcenter.utils.cssFix(pageElm); count++; }, 300); } function stopTimer() { if (_timer) { uw.clearInterval(_timer); _timer = null; } } var pageElm = document.getElementById("page"), count = 0; stopTimer(); startTimer(); }, false); } if (page === "embed") return; // We don't want the embed page to do these things. // UI ytcenter.classManagement.applyClassesExceptElement(document.body); try { ytcenter.thumbnail.setup(); ytcenter.domEvents.setup(); } catch (e) { con.error(e); } if (page === "feed_what_to_watch") { ytcenter.intelligentFeed.setup(); } if (ytcenter.settings["resize-default-playersize"] === "default") { ytcenter.player.currentResizeId = (ytcenter.settings.player_wide ? ytcenter.settings["resize-large-button"] : ytcenter.settings["resize-small-button"]); ytcenter.player.updateResize(); } else { ytcenter.player.currentResizeId = ytcenter.settings['resize-default-playersize']; ytcenter.player.updateResize(); } var id, config; if (page === "watch") { ytcenter.uploaderFlag.init(); ytcenter.page = "watch"; var wvi = document.getElementById("watch7-views-info"), sl = document.getElementsByClassName("video-extras-sparkbar-likes"), sd = document.getElementsByClassName("video-extras-sparkbar-dislikes"); if (sl && sd && sl.length > 0 && sd.length > 0 && sl[0] && sd[0]) { sl[0].style.background = ytcenter.settings.sparkbarLikesColor; sl[0].style.height = ytcenter.settings.sparkbarHeight + "px"; sd[0].style.background = ytcenter.settings.sparkbarDislikesColor; sd[0].style.height = ytcenter.settings.sparkbarHeight + "px"; sd[0].parentNode.style.height = ytcenter.settings.sparkbarHeight + "px"; } ytcenter.playlist = false; if (document.getElementById("watch7-playlist-data") || (loc && loc.search && typeof loc.search.indexOf === "function" && loc.search.indexOf("list=") !== -1)) { ytcenter.playlist = true; } var userHeader = document.getElementById("watch7-user-header"); var userName = document.getElementsByClassName("yt-user-name"); if (userName && userName.length > 1 && userName[1] && userName[1].textContent) { ytcenter.video.author = userName[1].textContent; } else if (userName && userName.length > 0 && userName[0] && userName[0].textContent) { ytcenter.video.author = userName[0].textContent; } if (ytcenter.video.author) { ytcenter.user.callChannelFeed(ytcenter.video.author, function(){ ytcenter.video._channel = this; ytcenter.video.channelname = this.title['$t']; }); } } else if (page === "channel") { ytcenter.page = "channel"; if (document.body.innerHTML.indexOf("data-video-id=\"") !== -1) { id = document.body.innerHTML.match(/data-video-id=\"(.*?)\"/)[1]; } else if (document.body.innerHTML.indexOf("/v/") !== -1) { id = document.body.innerHTML.match(/\/v\/([0-9a-zA-Z_-]+)/)[1]; } else if (document.body.innerHTML.indexOf("\/v\/") !== -1) { id = document.body.innerHTML.match(/\\\/v\\\/([0-9a-zA-Z_-]+)/)[1]; } if (id) { var url = ytcenter.utils.getLocationOrigin() + "/get_video_info?html5=0&cver=html5&dash=" + (ytcenter.settings.channel_dashPlayback ? "1" : "0") + "&video_id=" + id + "&eurl=" + encodeURIComponent(loc.href); con.log("Contacting: " + url); ytcenter.utils.xhr({ method: "GET", url: url, headers: { "Content-Type": "text/plain" }, onload: function(response){ try { if (response.responseText) { var o = {}; var s = response.responseText.split("&"); for (var i = 0; i < s.length; i++) { var ss = s[i].split("="); o[ss[0]] = decodeURIComponent(ss[1]); } ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), {args: o})); config = ytcenter.player.config; ytcenter.player.update(config); if (ytcenter.player.config.updateConfig) { ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); } } } catch (e) { con.error(response.responseText); con.error(e); } }, onerror: function(){ ytcenter.video.streams = []; } }); } } else if (page === "search") { ytcenter.page = "search"; } else { ytcenter.page = "normal"; } if (page === "watch") { ytcenter.actionPanel.setup(); ytcenter.player.setYTConfig({ "SHARE_ON_VIDEO_END": false }); ytcenter.player.setConfig(ytcenter.player.modifyConfig("watch", uw.ytplayer.config)); ytcenter.player.update(ytcenter.player.config); ytcenter.videoHistory.addVideo(ytcenter.player.config.args.video_id); } // Initialize the placement system if (page === "watch") { // Clear groups ytcenter.placementsystem.clearGroups(); var watch8ActionButtons = document.getElementById("watch8-action-buttons"); var watch8SecondaryActions = document.getElementById("watch8-secondary-actions"); var watch8SentimentActions = document.getElementById("watch8-sentiment-actions"); var ytcenterGroup = document.createElement("div"); ytcenterGroup.setAttribute("id", "watch8-ytcenter-buttons"); var userHeader = document.getElementById("watch7-user-header"); if (watch8ActionButtons) { if (watch8ActionButtons.children.length > 0) { watch8ActionButtons.insertBefore(ytcenterGroup, watch8ActionButtons.children[0]); } else { watch8ActionButtons.appendChild(ytcenterGroup); } } else if (userHeader && userHeader.nextElementSibling) { userHeader.parentNode.insertBefore(ytcenterGroup, userHeader.nextElementSibling); } else if (userHeader) { userHeader.parentNode.appendChild(ytcenterGroup); } else if (watch8ActionButtons) { watch8ActionButtons.parentNode.insertBefore(ytcenterGroup, watch8ActionButtons); } // Add the YouTube Center group ytcenter.placementsystem.createGroup("ytcenter", ytcenterGroup, {}); // Add the watch8-action-buttons group if (watch8SecondaryActions) { ytcenter.placementsystem.createGroup("watch8-secondary-actions", watch8SecondaryActions, {}); } // Add the watch8-sentiment-actions group if (watch8ActionButtons) { ytcenter.placementsystem.createGroup("watch8-sentiment-actions", watch8SentimentActions, {}); } // Creating buttons, which will be added to the ytcenter group $CreateDownloadButton(); $CreateRepeatButton(); $CreateLightButton(); $CreateAspectButton(); $CreateResizeButton(); var referenceList = ytcenter.placementsystem.createReferenceList(); ytcenter.placementsystem.placementGroupsReferenceList = referenceList; if (ytcenter.settings.placementGroups) { ytcenter.placementsystem.setSortList(ytcenter.settings.placementGroups, referenceList); } else { ytcenter.settings.placementGroups = ytcenter.placementsystem.getSortList(referenceList); } } }; ytcenter.pageReadinessListener.addEventListener("bodyInteractive", function(){ var page = ytcenter.getPage(); if (page === "embed" && !ytcenter.settings.embed_enabled) return; /* Only need to handle the Google+ comments */ if (page === "comments") { ytcenter.commentsPlus.setup(); return; } ytcenter.unsafe.subtitles = ytcenter.subtitles; ytcenter.pageSetup(); yt = uw.yt; if (page === "embed") { ytcenter.player.listeners.setup(); } ytcenter.player.onYouTubePlayerReady = function(api){ if (!ytcenter.player.config) return; /* Running other onYouTubePlayerReady callbacks */ if (ytcenter.onYouTubePlayerReady) { var i; for (i = 0; i < ytcenter.onYouTubePlayerReady.length; i++) { ytcenter.onYouTubePlayerReady[i].apply(uw, arguments); } ytcenter.onYouTubePlayerReady = []; } ytcenter.classManagement.applyClassesForElement(); if (typeof api === "object") { ytcenter.player.__getAPI = api; api = ytcenter.player.getAPI(); ytcenter.html5 = (api && typeof api.getPlayerType === "function" && api.getPlayerType() === "html5" && !ytcenter.player.isLiveStream() && !ytcenter.player.isOnDemandStream()); ytcenter.player._update_onYouTubeReady = true; if (!ytcenter.html5) { if (uw && uw.yt && uw.yt.player && uw.yt.player.utils && uw.yt.player.utils.VideoTagPool && uw.yt.player.utils.VideoTagPool.instance_ && uw.yt.player.utils.VideoTagPool.instance_.g && ytcenter.utils.isArray(uw.yt.player.utils.VideoTagPool.instance_.g)) { for (var i = 0, len = uw.yt.player.utils.VideoTagPool.instance_.g.length; i < len; i++) { yt.player.utils.VideoTagPool.instance_.g[i].src = ""; yt.player.utils.VideoTagPool.instance_.g[i].pause && yt.player.utils.VideoTagPool.instance_.g[i].pause(); if (yt.player.utils.VideoTagPool.instance_.g[i].parentNode) { yt.player.utils.VideoTagPool.instance_.g[i].parentNode.removeChild(yt.player.utils.VideoTagPool.instance_.g[i]); } uw.yt.player.utils.VideoTagPool.instance_.g.splice(i, 1); i--; len--; } } } ytcenter.player.listeners.dispose(); ytcenter.player.listeners.setup(); if (ytcenter.getPage() === "channel") { if (ytcenter.player.config && ytcenter.player.config.args) { ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); } else { if (ytcenter.player.config === null) ytcenter.player.config = {}; ytcenter.player.config.updateConfig = true; } } else { if (ytcenter.getPage() === "watch") { if (ytcenter.player.config) { try { ytcenter.player.updateConfig(loc.href, ytcenter.player.modifyConfig(ytcenter.getPage(loc.href), ytcenter.player.config)); ytcenter.videoHistory.addVideo(ytcenter.player.config.args.video_id); } catch (e) { con.error(e); } } ytcenter.topScrollPlayer.setEnabled(ytcenter.settings.topScrollPlayerEnabled); } else if (ytcenter.getPage() === "embed") { var lis = function(state){ if (state === -1) return; ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); if (state === 1 || state === 2 || state === 3) ytcenter.player.listeners.removeEventListener("onStateChange", lis); }; ytcenter.player.listeners.addEventListener("onStateChange", lis); ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); } ytcenter.tabEvents.addEventListener("player", function(playerFunction){ var api = ytcenter.player.getAPI(); if (!api && api[playerFunction]) { con.error("[Tab Events] Player API \"" + playerFunction + "\" not found!"); } else { api[playerFunction].apply(api, Array.prototype.slice.call(arguments, 1)); } }); con.log("[onYouTubePlayerReady] => updateConfig"); ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); ytcenter.classManagement.applyClasses(); } } }; var apiChangedEnabled = true; ytcenter.player.listeners.addEventListener("onApiChange", function(){ /*if (!apiChangedEnabled) { ytcenter.player.updateConfig(ytcenter.getPage(), ytcenter.player.config); apiChangedEnabled = true; } var api = ytcenter.player.getAPI(); if (api && api.getUpdatedConfigurationData) { var newData = api.getUpdatedConfigurationData(); con.log(newData); ytcenter.player.setConfig(ytcenter.player.modifyConfig(ytcenter.getPage(), newData)); apiChangedEnabled = false; var cfg = ytcenter.player.config; con.log(cfg); if (ytcenter.topScrollPlayer.isActive()) { ytcenter.topScrollPlayer.setRedirectURL("/watch?v=" + encodeURIComponent(cfg.args.video_id) + "&list=" + encodeURIComponent(cfg.args.list)); } if (api.loadNewVideoConfig) { api.loadNewVideoConfig(cfg); } else if (api.loadVideoByPlayerVars) { api.loadVideoByPlayerVars(cfg.args); } }*/ }); ytcenter.player.listeners.addEventListener("onReady", function(api){ var config = ytcenter.player.getConfig(); if (ytcenter.settings.enableAutoVideoQuality) { ytcenter.player.setQuality(ytcenter.player.getQuality(ytcenter.settings.autoVideoQuality, ytcenter.video.streams, (config.args.dash === "1" && config.args.adaptive_fmts ? true : false))); } }); ytcenter.unsafe.player = ytcenter.unsafe.player || {}; ytcenter.unsafe.player.setAspect = ytcenter.player.aspect; ytcenter.unsafe.player.getAPI = ytcenter.utils.oldBind(ytcenter.player.getAPI, ytcenter.unsafe); ytcenter.unsafe.player.onReady = ytcenter.utils.oldBind(ytcenter.player.onYouTubePlayerReady, ytcenter.unsafe); ytcenter.unsafe.player.parseThumbnailStream = ytcenter.player.parseThumbnailStream; ytcenter.unsafe.player.showMeMyThumbnailStream = function(index){ var a = ytcenter.player.parseThumbnailStream(ytcenter.player.config.args.storyboard_spec), b = a.levels[(typeof index === "number" && index > 0 && index < a.levels.length ? index : a.levels.length) - 1], elm = document.createElement("div"), pic = document.createElement("div"), box = {width: 1280, height: 720}, rect = b.getRect(0, box), i = 0; pic.style.width = rect.width + "px"; pic.style.height = rect.height + "px"; pic.style.backgroundImage = "URL(" + b.getURL(0) + ")"; pic.style.backgroundSize = rect.imageWidth + "px " + rect.imageHeight + "px"; pic.style.backgroundPosition = rect.x + "px " + -rect.y + "px"; ytcenter.utils.addEventListener(document.body, "keyup", function(e){ if (e.keyCode === 37) { i--; } else if (e.keyCode === 39) { i++; } if (b.frames <= i) i = 0; if (i < 0) i = b.frames - 1; rect = b.getRect(i, box); pic.style.backgroundImage = "URL(" + b.getURL(i) + ")"; pic.style.backgroundPosition = -rect.x + "px " + -rect.y + "px"; }, false); elm.appendChild(pic); ytcenter.dialog(null, elm).setVisibility(true); }; if (typeof uw.onYouTubePlayerReady === "function") { if (!ytcenter.onYouTubePlayerReady) ytcenter.onYouTubePlayerReady = []; ytcenter.onYouTubePlayerReady.push(uw.onYouTubePlayerReady); } defineLockedProperty(uw, "onYouTubePlayerReady", function(func){ con.log("[onYouTubePlayerReady] Something is trying to set onYouTubePlayerReady to something else."); if (typeof func !== "function") return; if (!ytcenter.onYouTubePlayerReady) ytcenter.onYouTubePlayerReady = []; ytcenter.onYouTubePlayerReady.push(func); }, function(){ return ytcenter.player.onYouTubePlayerReady; }); /* bodyInteractive should only be used for the UI, use the other listeners for player configuration */ ytcenter.player.listeners.addEventListener("onReady", function(){ var api = null, state = null; if (ytcenter.player.getAPI) api = ytcenter.player.getAPI(); if (api && api.getPlayerState) state = ytcenter.player.getAPI().getPlayerState(); if (state === 1 && ytcenter.settings.playerOnlyOneInstancePlaying && !ytcenter.player.isPreventAutoBuffering() && !ytcenter.player.isPreventAutoPlay()) { if ((ytcenter.getPage() === "embed" && ytcenter.settings.embed_enabled) || ytcenter.getPage() !== "embed") { ytcenter.player.network.pause(); } } }); ytcenter.player.listeners.addEventListener("onStateChange", function(state){ if (ytcenter.player.setPlaybackState.preferredState !== null) state = ytcenter.player.setPlaybackState.preferredState; if (state === 1 && ytcenter.settings.playerOnlyOneInstancePlaying) { if ((ytcenter.getPage() === "embed" && ytcenter.settings.embed_enabled) || ytcenter.getPage() !== "embed") { ytcenter.player.network.pause(); } } }); if (page === "embed") { /* I've moved ytcenter.embed.load to be executed when the page has completely loaded */ //@embed return; } $CreateSettingsUI(); $UpdateChecker(); ytcenter.player.listeners.addEventListener("onAdStart", function(type){ if (type === "PREROLL") { if (ytcenter.getPage() === "watch") { if (ytcenter.playlist) { if (ytcenter.settings.preventPlaylistAutoPlay) { ytcenter.player.getAPI().mute(); ytcenter.player.getAPI().pauseVideo(); !ytcenter.settings.mute && ytcenter.player.getAPI().isMuted && ytcenter.player.getAPI().unMute(); } } else { if (ytcenter.settings.preventAutoPlay) { ytcenter.player.getAPI().mute(); ytcenter.player.getAPI().pauseVideo(); !ytcenter.settings.mute && ytcenter.player.getAPI().isMuted && ytcenter.player.getAPI().unMute(); } } } else if (ytcenter.getPage() === "channel") { if (ytcenter.settings.channel_preventAutoPlay) { ytcenter.player.getAPI().mute(); ytcenter.player.getAPI().pauseVideo(); !ytcenter.settings.channel_mute && ytcenter.player.getAPI().isMuted && ytcenter.player.getAPI().unMute(); } } else if (ytcenter.getPage() === "embed") { if (ytcenter.settings.embed_preventAutoPlay) { ytcenter.player.getAPI().mute(); ytcenter.player.getAPI().pauseVideo(); !ytcenter.settings.embed_mute && ytcenter.player.getAPI().isMuted && ytcenter.player.getAPI().unMute(); } } } }); ytcenter.player.listeners.addEventListener("onReady", function(){ var api, state; if (ytcenter.player.getAPI) api = ytcenter.player.getAPI(); if (api && api.getPlayerState) state = ytcenter.player.getAPI().getPlayerState(); if (state === 1) { ytcenter.title.addPlayIcon(); } else { ytcenter.title.removePlayIcon(); } ytcenter.title.update(); }); var tmpFixRepeatAtEnd = false; ytcenter.player.listeners.addEventListener("onStateChange", function(state, b){ if (state === 1) { ytcenter.title.addPlayIcon(); } else { ytcenter.title.removePlayIcon(); } ytcenter.title.update(); if (ytcenter.doRepeat && ytcenter.settings.enableRepeat && state === 0) { if (ytcenter.settings.tempFixRepeat) { ytcenter.player.getAPI().stopVideo(); } ytcenter.player.getAPI().playVideo(); } if (ytcenter.settings.endOfVideoAutoSwitchToTab !== "none" && state === 0) { ytcenter.actionPanel.switchTo(ytcenter.settings.endOfVideoAutoSwitchToTab); } }); ytcenter.player.listeners.setOverride("SIZE_CLICKED", true); ytcenter.player.listeners.addEventListener("SIZE_CLICKED", function(large){ function getSizeById(id) { var sizes = ytcenter.settings["resize-playersizes"]; for (var i = 0; i < sizes.length; i++) { if (id === sizes[i].id) { return sizes[i]; } } return { id: "default", config: { align: true, height: "", large: false, scrollToPlayer: false, scrollToPlayerButton: false, width: "" } }; } if (ytcenter.settings.enableResize) { con.log("[Player Resize] Setting to " + (large ? "large" : "small") + "!"); if (large) { ytcenter.player.setPlayerWide(true); ytcenter.player.currentResizeId = ytcenter.settings['resize-large-button']; ytcenter.player.updateResize(); } else { ytcenter.player.setPlayerWide(false); ytcenter.player.currentResizeId = ytcenter.settings['resize-small-button']; ytcenter.player.updateResize(); } } else { this.getOriginalListener()(large); } }); /*if (ytcenter.feather) { var flashvars = document.getElementById("movie_player").getAttribute("flashvars").split("&"), args, i; for (i = 0; i < flashvars.length; i++) { args[decodeURIComponent(flashvars.split("=")[0])] = decodeURIComponent(flashvars.split("=")[0]); ytcenter.player.setConfig({args: args}); } }*/ if (loc.hash === "#ytcenter.settings.open") { ytcenter.unsafe.openSettings(); } }); ytcenter.pageReadinessListener.addEventListener("bodyComplete", function(page){ if (page === "embed" && !ytcenter.settings.embed_enabled) return; if (page === "comments") { ytcenter.domEvents.ready(); } if (page === "embed") { ytcenter.embed.load(); } else { ytcenter.guideMode.setup(); } ytcenter.spf.setEnabled(ytcenter.settings.ytspf); ytcenter.classManagement.applyClassesForElement(document.body); if (loc.hash === "#ytcenter.settings.open") { loc.hash = "#!"; } }); ytcenter.spf.addEventListener("request", function(e) { var detail = e.detail; ytcenter.player.setConfig(null); ytcenter.descriptionTags.destroy(); }); ytcenter.spf.addEventListener("process", function(e) { var detail = e.detail; if (detail && detail.response && detail.response.title) { ytcenter.title.originalTitle = detail.response.title; ytcenter.title.update(); } }); ytcenter.spf.addEventListener("partprocess", function(e) { var detail = e.detail; var url = detail.url; if (detail && detail.part) { var part = detail.part; if (part.title) { ytcenter.title.originalTitle = part.title; ytcenter.title.update(); } var swfcfg = null; if (part.swfcfg) { swfcfg = part.swfcfg; } else if (part.data && part.data.swfcfg) { swfcfg = part.data.swfcfg; } if (swfcfg) { /*swfcfg = ytcenter.player.modifyConfig(ytcenter.getPage(url), swfcfg); ytcenter.player.setConfig(swfcfg);*/ if (swfcfg.args && swfcfg.args.video_id) { ytcenter.videoHistory.addVideo(swfcfg.args.video_id); } } if (part.attr && part.attr.body && part.attr.body.class) { part.attr.body.class += " " + ytcenter.classManagement.getClassesForElementByTagName("body", url); } } }); ytcenter.spf.addEventListener("done", function(e) { var detail = e.detail; var url = detail.url; ytcenter.classManagement.applyClasses(url); ytcenter.pageSetup(); /* Removing leftover tooltips */ a = ytcenter.utils.transformToArray(document.getElementsByClassName("yt-uix-tooltip-tip")); for (i = 0; i < a.length; i++) { if (a[i] && a[i].parentNode === document.body) { con.log("[Tooltip Cleanup] Removed tooltip with id #" + a[i].id.replace("yt-uix-tooltip", "")); document.body.removeChild(a[i]); } } if (ytcenter.player.getConfig() !== null) { setTimeout(function(){ con.debug("[IssueTmpFix] Player not loading correct video."); var api = ytcenter.player.getAPI(); api.loadVideoByPlayerVars(ytcenter.player.getConfig().args); ytcenter.player.onYouTubePlayerReady(api); }, 1000); } }); ytcenter.pageReadinessListener.setup(); })(); }; // Utils 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 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; } function trimLeft(obj){ return obj.replace(/^\s+/, ""); } function trimRight(obj){ return obj.replace(/\s+$/, ""); } 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() { 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; } var now = Date.now || function () { return +new Date; }; // Support var support = (function(){ function localStorageTest() { try { localStorage.setItem(mod, mod); localStorage.removeItem(mod); return true; } catch (e) { return false; } } function customEvent() { 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; } } var mod = "support.test"; return { localStorage: localStorageTest(), Greasemonkey: (typeof GM_setValue !== "undefined" && (typeof GM_setValue.toString === "undefined" || GM_setValue.toString().indexOf("not supported") === -1)), Adguard: (typeof AdguardSettings === "object"), cloneInto: (typeof cloneInto === "function"), CustomEvent: customEvent() }; })(); // Chrome API function chrome_save(id, key, data) { if (typeof data !== "string") data = JSON.stringify(data); if (chrome && chrome.storage && chrome.storage.local) { var storage = chrome.storage.local; var details = {}; details[key] = data; storage.set(details); } else { console.warn("[Chrome] Chrome extension API is not present!"); setTimeout(function(){ defaultSave(id, key, data); }, 7); } } function chrome_load(id, key) { if (chrome && chrome.storage && chrome.storage.local) { var storage = chrome.storage.local; var value = null; if ((value = localStorage.getItem(key) || null) !== null) { console.log("[Chrome] Moving settings from old method to new method for " + key); var details = {}; details[key] = value; storage.set(details); localStorage.removeItem(key); callUnsafeWindow(id, value); } else { storage.get(key, function(result) { var res = {}; if (key in result) { res = result[key]; } callUnsafeWindow(id, res); }); } } else { console.warn("[Chrome] Chrome extension API is not present!"); setTimeout(function(){ defaultLoad(id, key); }, 7); } } // Safari API function safariMessageListener(e) { if (!e || !e.message) return; // Checking if data is present if (typeof e.message !== "string") return; // Checking if the object is a string. if (!e.message.indexOf || e.message.indexOf("{") !== 0) return; var d = JSON.parse(e.message); if (d.level !== "safe") { return; } if (e.name === "call") { var args = [d.id].concat(d.arguments); callUnsafeWindow.apply(null, args); } } // Opera API function operaMessageListener(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 d = JSON.parse(e.data); if (d.level !== "safe") { return; } callUnsafeWindow.apply(null, [d.id].concat(d.arguments)); } // Firefox API function onFirefoxEvent() { callUnsafeWindow.apply(null, arguments); } // General function callUnsafeWindow(id) { if (typeof id === "number" || typeof id === "string") { if (support.CustomEvent) { callUnsafeWindowEvent.apply(null, arguments); } else { callUnsafeWindowMessage.apply(null, arguments); } } } function callUnsafeWindowMessage(id) { if (typeof id === "number" || typeof id === "string") { var args = Array.prototype.slice.call(arguments, 1); window.postMessage(JSON.stringify({ level: "safe", id: id, arguments: args }), "*"); } } function callUnsafeWindowEvent(id) { if (typeof id === "number" || typeof id === "string") { var args = Array.prototype.slice.call(arguments, 1); var detail = { id: id, arguments: args }; // Firefox 30 or newer /*if (support.cloneInto) { detail = cloneInto(detail, document.defaultView); }*/ var e = document.createEvent("CustomEvent"); e.initCustomEvent("ytc-page-call", true, true, JSON.stringify(detail)); document.documentElement.dispatchEvent(e); } } function eventListener(e) { var detail = JSON.parse(e.detail); if (0 === 4) { // Safari safari.self.tab.dispatchMessage("call", e.detail); // Redirect event to the extension } else if (0 === 5) { // Opera opera.extension.postMessage(e.detail); // Redirect event to the extension } else { setTimeout(function(){ handleMethods(detail); }, 0); } if (e && typeof e.stopPropagation === "function") e.stopPropagation(); } function messageListener(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 d = JSON.parse(e.data); if (d.level !== "unsafe") { return; } if (0 === 4) { // Safari safari.self.tab.dispatchMessage("call", e.data); // Redirect message to the extension } else if (0 === 5) { // Opera opera.extension.postMessage(e.data); // Redirect message to the extension } else { handleMethods(d); } } function handleMethods(data) { switch (data.method) { case "xhr": xhr(data.arguments[0]); break; case "save": save(data.id, data.arguments[0], data.arguments[1]); break; case "load": load(data.id, data.arguments[0]); break; case "firefox_addWindowListener": addWindowListener(bind(null, callUnsafeWindow, data.id)); break; case "firefox_windowLinkerFireRegisteredEvent": windowLinkerFireRegisteredEvent.apply(null, data.arguments); break; case "GM_registerMenuCommand": if (support.Greasemonkey) { setTimeout(function(){ GM_registerMenuCommand(data.arguments[0], bind(null, callUnsafeWindow, data.id)); }, 7); } break; default: console.log("Unknown method: " + method + ", with data:", data); } } function adguard_xhr_getURL(details) { var encodeHeaders = function (headers) { if (typeof headers == "object") { var result = ""; for (header in headers) result += encodeURIComponent(header) + ":" + encodeURIComponent(headers[header]) + ","; return result.slice(0, -1) } if (typeof headers == "string") return encodeURIComponent(headers); return null }; var url = (settings.testDomain ? settings.testDomain : utils.getHostWithProtocol()) + settings.apiurl + settings.apiType + "?type=gm-xml-http-request"; var urlData = {}; urlData.url = encodeURIComponent(details.url || ""); urlData.data = encodeURIComponent(details.data || ""); urlData.headers = encodeHeaders(details.headers || ""); urlData.method = encodeURIComponent(details.method || ""); urlData.overridemimetype = encodeURIComponent(details.overridemimetype || ""); urlData.user = encodeURIComponent(details.user || ""); urlData.password = encodeURIComponent(details.password || ""); var prepareURL = []; for (var key in urlData) { if (urlData.hasOwnProperty(key)) { prepareURL.push(key + "=" + urlData[key]); } } url += "&" + prepareURL.join("&"); return url; } function adguard_xhr(details) { var xmlhttp; if (typeof XMLHttpRequest !== "undefined") { xmlhttp = new XMLHttpRequest(); } else if (typeof opera !== "undefined" && typeof opera.XMLHttpRequest !== "undefined") { xmlhttp = new opera.XMLHttpRequest(); } else { details["onerror"](responseState); return; } xmlhttp.onreadystatechange = function(){ var responseState = { responseXML: '', responseText: (xmlhttp.readyState == 4 ? xmlhttp.responseText : ''), readyState: xmlhttp.readyState, responseHeaders: (xmlhttp.readyState == 4 ? xmlhttp.getAllResponseHeaders() : ''), status: (xmlhttp.readyState == 4 ? xmlhttp.status : 0), statusText: (xmlhttp.readyState == 4 ? xmlhttp.statusText : ''), finalUrl: (xmlhttp.readyState == 4 ? xmlhttp.finalUrl : '') }; if (details["onreadystatechange"]) { details["onreadystatechange"](responseState); } if (xmlhttp.readyState == 4) { if (details["onload"] && xmlhttp.status >= 200 && xmlhttp.status < 300) { details["onload"](responseState); } if (details["onerror"] && (xmlhttp.status < 200 || xmlhttp.status >= 300)) { details["onerror"](responseState); } } }; try { xmlhttp.open(details.method, adguard_xhr_getURL(details)); } catch (e) { details["onerror"](); } if (details.headers) { for (var prop in details.headers) { xmlhttp.setRequestHeader(prop, details.headers[prop]); } } xmlhttp.send((typeof(details.data) !== 'undefined') ? details.data : null); } function xhr(details) { createCallableDetails(details); if (0 === 6) { // Firefox request(details); } else if (support.Greasemonkey) { setTimeout(function(){ GM_xmlhttpRequest(details); }, 7); } else { var xmlhttp; if (typeof XMLHttpRequest != "undefined") { xmlhttp = new XMLHttpRequest(); } else if (typeof opera != "undefined" && typeof opera.XMLHttpRequest != "undefined") { xmlhttp = new opera.XMLHttpRequest(); } else { details["onerror"](responseState); } xmlhttp.onreadystatechange = function(){ var responseState = { responseXML: '', responseText: (xmlhttp.readyState == 4 ? xmlhttp.responseText : ''), readyState: xmlhttp.readyState, responseHeaders: (xmlhttp.readyState == 4 ? xmlhttp.getAllResponseHeaders() : ''), status: (xmlhttp.readyState == 4 ? xmlhttp.status : 0), statusText: (xmlhttp.readyState == 4 ? xmlhttp.statusText : ''), finalUrl: (xmlhttp.readyState == 4 ? xmlhttp.finalUrl : '') }; if (details["onreadystatechange"]) { details["onreadystatechange"](responseState); } if (xmlhttp.readyState == 4) { if (details["onload"] && xmlhttp.status >= 200 && xmlhttp.status < 300) { details["onload"](responseState); } if (details["onerror"] && (xmlhttp.status < 200 || xmlhttp.status >= 300)) { details["onerror"](responseState); } } }; try { xmlhttp.open(details.method, details.url); } catch(e) { details["onerror"](); } if (details.headers) { for (var prop in details.headers) { xmlhttp.setRequestHeader(prop, details.headers[prop]); } } xmlhttp.send((typeof(details.data) !== 'undefined') ? details.data : null); } } function createCallableDetails(details) { var callback = ["abort", "error", "load", "progress", "readystatechange", "timeout"]; for (var i = 0, len = callback.length; i < len; i++) { var on = details["on" + callback[i]]; if (typeof on === "number") { details["on" + callback[i]] = bind(null, callUnsafeWindow, on); } } } function save(id, key, data) { if (typeof data !== "string") data = JSON.stringify(data); if (0 === 1 || 0 === 8) { chrome_save(id, key, data); } else if (0 === 2) { callUnsafeWindow(id, window.external.mxGetRuntime().storage.setConfig(key, data)); } else if (0 === 6) { callUnsafeWindow(id, storage_setValue(key, data)); } else { setTimeout(function(){ defaultSave(id, key, data); }, 7); } } function defaultSave(id, key, data) { if (support.Greasemonkey) { callUnsafeWindow(id, GM_setValue(key, data)); } else if (support.localStorage) { callUnsafeWindow(id, localStorage.setItem(key, data)); } else { callUnsafeWindow(id, setCookie(key, data, null, "/", 86400000000)); } } function load(id, key) { if (0 === 1 || 0 === 8) { chrome_load(id, key); } else if (0 === 2) { callUnsafeWindow(id, window.external.mxGetRuntime().storage.getConfig(key) || "{}"); } else if (0 === 6) { callUnsafeWindow(id, storage_getValue(key) || "{}"); } else { setTimeout(function() { defaultLoad(id, key); }, 7); } } function defaultLoad(id, key) { if (support.Greasemonkey) { callUnsafeWindow(id, GM_getValue(key) || "{}"); } else if (support.localStorage) { callUnsafeWindow(id, localStorage.getItem(key) || "{}"); } else { callUnsafeWindow(id, getCookie(key) || "{}"); } } function windowUnload() { window.removeEventListener("message", messageListener, false); window.removeEventListener("unload", windowUnload, false); if (0 === 4) { // Safari safari.self.removeEventListener("message", safariMessageListener, false); } else if (0 === 5) { // Opera opera.extension.onmessage = null; } } function isDomainAllowed(domains) { var domain = document.domain; for (var i = 0, len = domains.length; i < len; i++) { if (domain === domains[i]) { return true; } } return false; } function initListeners() { if (support.CustomEvent) { window.addEventListener("ytc-content-call", eventListener, false); } else { window.addEventListener("message", messageListener, false); } window.addEventListener("unload", windowUnload, false); if (0 === 4) { // Safari safari.self.addEventListener("message", safariMessageListener, false); } else if (0 === 5) { // Opera opera.extension.onmessage = operaMessageListener; } } var domains = ["www.youtube.com", "youtube.com", "apis.google.com", "plus.googleapis.com"]; if (isDomainAllowed(domains)) { // Let's do a check to see if YouTube Center should run. console.log("Domain registered " + document.domain + "."); initListeners(); inject(main_function); } else { throw "Domain " + document.domain + " not allowed!"; } })();