// ==UserScript==
// @name Cosmic Cat
// @namespace https://www.youtube.com/*
// @version 0.8
// @description Broadcast Yourself
// @author Thistle Café, Cosmic Cat Maintainers
// @license The Unlicense
// @match https://www.youtube.com/*
// @exclude https://www.youtube.com/embed/*
// @exclude https://www.youtube.com/live_chat*
// @icon https://github.com/cosmic-cat-yt/cosmic-cat-branding/raw/main/icon.png
// @require https://code.jquery.com/jquery-3.6.1.min.js
// @grant unsafeWindow
// @grant GM_addStyle
// @grant GM.getValue
// @grant GM.setValue
// @grant GM_xmlhttpRequest
// @grant GM_registerMenuCommand
// @grant GM_deleteValue
// @grant GM_listValues
// @grant GM_getResourceText
// @grant GM_getResourceURL
// @grant GM_log
// @grant GM_openInTab
// @grant GM_setClipboard
// @grant GM_info
// @run-at document-start
// ==/UserScript==
// Generated by compile script. See GitHub for source code.
// https://github.com/cosmic-cat-yt/cosmic-cat
(function (exports) {
'use strict';
/******************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise, SuppressedError, Symbol */
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
var e = new Error(message);
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
};
/**
* An array of all of the active event handlers.
*/
var handlers = {};
function isActiveEventName(name) {
return Object.keys(handlers).includes(name);
}
function getDelegateHandler(eventName) {
return function (event) {
var activeElement = event.target;
var classNameList = handlers[eventName];
while (null != activeElement) {
if (activeElement.className) {
var classes;
if (activeElement.classList) {
classes = activeElement.classList;
}
else {
classes = activeElement.classList.split(" ");
}
for (var i = 0, l = classes.length; i < l; i++) {
if (classes[i] in classNameList) {
return classNameList[classes[i]](activeElement, event);
}
}
}
// If there's nothing in this element, look at its parent.
activeElement = activeElement.parentElement;
}
};
}
function addHandler(eventName, className, handler) {
if (!isActiveEventName(eventName)) {
// Create a new event listener if there is none
// already declared.
document.addEventListener(eventName, getDelegateHandler(eventName));
}
// Add the handler to the internal array.
if (!(eventName in handlers)) {
handlers[eventName] = {};
}
handlers[eventName][className] = handler;
}
var uid = 0;
function getUid() {
return uid++;
}
/**
* Handle thumbnail delayloading
*/
function handleDelayload() {
var thumbnails = document.querySelectorAll(".yt-thumb, .yt-uix-simple-thumb-wrap");
for (var i = 0, l = thumbnails.length; i < l; i++) {
if (!thumbnails[i].loaded) {
var bounds = thumbnails[i].getBoundingClientRect();
if (bounds.top > window.innerHeight)
return;
var img = thumbnails[i].querySelector("img");
img.src = img.getAttribute("data-thumb");
img.removeAttribute("data-thumb");
thumbnails[i].loaded = true;
}
}
}
function onClickExpander(expander, event) {
var closestMain = expander.closest(".yt-uix-expander");
if (closestMain.classList.contains("yt-uix-expander-expanded")) {
closestMain.classList.remove("yt-uix-expander-expanded");
closestMain.classList.add("yt-uix-expander-collapsed");
}
else {
closestMain.classList.add("yt-uix-expander-expanded");
closestMain.classList.remove("yt-uix-expander-collapsed");
}
}
function tooltip(element, event) {
function getTooltipText(element) {
return element.getAttribute("data-tooltip-text") || element.title || element._tooltipTitle;
}
function createTipBase(elm) {
var text = getTooltipText(elm);
console.log(text);
if (!text)
return;
var base = document.createElement("div");
base.className = "yt-uix-tooltip-tip";
base.id = "yt-uix-tooltip" + getUid();
var body = document.createElement("div");
body.className = "yt-uix-tooltip-tip-body";
var arrow = document.createElement("div");
arrow.className = "yt-uix-tooltip-tip-arrow";
var content = document.createElement("div");
content.className = "yt-uix-tooltip-tip-content";
content.innerText = text;
body.appendChild(content);
base.appendChild(body);
base.appendChild(arrow);
elm._boundTooltip = base;
if (elm._boundTooltip)
document.body.appendChild(elm._boundTooltip);
positionTip(elm, base, body);
}
function positionTip(elm, base, body, content) {
var isReverse = false;
var elmRect = elm.getBoundingClientRect();
var bodyRect = body.getBoundingClientRect();
if (elmRect.y < 32 || elm.getAttribute("data-tooltip-force-direction")) {
isReverse = true;
}
if (isReverse) {
base.classList.add("yt-uix-tooltip-tip-reverse");
}
var x = (elmRect.left + ((elmRect.width) / 2)) - 5;
var y = (!isReverse ? elmRect.top + window.scrollY : elmRect.top + elmRect.height + window.scrollY);
base.style.left = x + "px";
base.style.top = y + "px";
body.style.left = -1 * ((bodyRect.width / 2) - 5) + "px";
}
if (element.hasAttribute("title")) {
element._tooltipTitle = element.getAttribute("title");
}
element.removeAttribute("title");
if (!element._boundTooltip)
createTipBase(element);
// Animation hack
setTimeout(function () {
if (element._boundTooltip)
element._boundTooltip.classList.add("yt-uix-tooltip-tip-visible");
}, 5);
function onMouseLeave() {
removeTooltip(element);
element.removeEventListener("mouseleave", onMouseLeave);
}
function onClick() {
removeTooltip(element);
element.removeEventListener("click", onClick);
}
element.addEventListener("mouseleave", onMouseLeave);
element.addEventListener("click", onClick);
}
function removeTooltip(element) {
if (!element || !element._boundTooltip)
return;
var tooltip = element._boundTooltip;
tooltip.remove();
if (element._tooltipTitle) {
element.setAttribute("title", element._tooltipTitle);
}
delete element._boundTooltip;
}
function init() {
addHandler("click", "yt-uix-expander-head", onClickExpander);
addHandler("mouseover", "yt-uix-tooltip", tooltip);
// No focus outline behaviour
document.addEventListener("keydown", function () {
document.documentElement.classList.remove("no-focus-outline");
});
document.addEventListener("mousemove", function () {
document.documentElement.classList.add("no-focus-outline");
});
// Hook scroll events
window.addEventListener("scroll", handleDelayload);
window.addEventListener("resize", handleDelayload);
document.addEventListener("DOMContentLoaded", function a() {
handleDelayload();
document.removeEventListener("DOMContentLoaded", a);
});
}
function vorapisPlayer(innertubevideoid, mission) {
// Install player script.
var _aaa = document.createElement("script");
_aaa.setAttribute("src", "//cosmic-cat-yt.github.io/cosmic-cat/html5player.js");
_aaa.onload = function () {
(playerwasloaded = !0),
datawasloaded && (invokePlayer(), (playerwasinvoked = !0));
};
document.head.appendChild(_aaa);
// Install player skin.
const ass = document.createElement("style");
ass.id = "cosmic-panda-player";
ass.innerHTML = `
.ytp-play-progress {
background-image: linear-gradient(to bottom,#c00 0,#600 100%);
}
.ytp-load-progress {
background-image: linear-gradient(to top,#5a5a5a 89%,#666 90%);
}
.html5-scrubber-button {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-common-vflzogr__.png) -305px -41px;
border:none;
width:17px;
height:16px!important;
border-radius:0;
top:-6px
}
.html5-progress-bar:focus .html5-scrubber-button, .html5-scrubber-button:active, .html5-scrubber-button:hover {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-common-vflzogr__.png) 0 0;
}
.ytp-progress-list {
background: #1e1f1f;
background-image: linear-gradient(to top,rgba(30,31,31,.75) 89%,#2f2f2f 90%);
}
.html5-video-player .html5-player-chrome {
padding-bottom:1px;
height:26px;
background:url('')
}
button.ytp-v3normal.ytp-button {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -96px -151px;
}
button.ytp-v3normal.ytp-button:hover {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -97px
}
#player.watch-small button.ytp-v3normal.ytp-button {
background:no-repeat url(//s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -96px -151px, #141414;
box-shadow: inset 0 -5px 5px #000;
}
#player.watch-medium button.ytp-v3teather.ytp-button, .ytp-size-toggle-large:focus {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -121px -340px, #141414;
box-shadow: inset 0 -5px 5px #000;
}
button.ytp-v3teather.ytp-button, .ytp-size-toggle-large {
background: no-repeat url(//s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -121px -340px;
}
button.ytp-v3teather.ytp-button:hover, .ytp-size-toggle-large:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -32px -43px;
}
.ytp-button-fullscreen-enter, .ytp-embed .ytp-fullscreen-button.ytp-button {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -128px -43px;
}
.ytp-button-fullscreen-enter:not(.ytp-disabled):focus, .ytp-button-fullscreen-enter:not(.ytp-disabled):hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -89px -340px;
}
.ytp-settings-button {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -89px -70px;
}
.ytp-settings-button:hover, .ytp-settings-button:not(.ytp-disabled):focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -35px -259px!important;
}
.ytp-settings-button-active {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -35px -259px, #141414!important;
box-shadow: inset 0 -5px 5px #000;
}
.ytp-subtitles-button,.ytp-subtitles-button:focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -151px;
}
.ytp-subtitles-button:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -57px -340px;
}
.ytp-subtitles-button-active:focus, .ytp-subtitles-button-active:hover, .ytp-subtitles-button-active {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -128px -178px;
}
.ytp-button-watch-later, .ytp-button-watch-later:focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -96px -178px;
}
.ytp-button-watch-later:hover, .ytp-button-watch-later:active {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -96px -124px;
}
.ytp-button-volume[data-value=max], .ytp-button-volume[data-value=loud], .ytp-button-volume[data-value=max]:focus, .ytp-button-volume[data-value=loud]:focus, .ytp-embed .ytp-mute-button {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -232px;
}
.ytp-button-volume[data-value=max]:hover, .ytp-button-volume[data-value=loud]:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -178px;
}
.ytp-button-volume[data-value=normal], .ytp-button-volume[data-value=quiet], .ytp-button-volume[data-value=normal]:focus, .ytp-button-volume[data-value=quiet]:focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -32px -178px;
}
.ytp-button-volume[data-value=normal]:hover, .ytp-button-volume[data-value=quiet]:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -92px -259px;
}
.ytp-button-volume[data-value=min], .ytp-button-volume[data-value=min]:focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -124px;
}
.ytp-button-volume[data-value=min]:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -124px;
}
.ytp-button-volume[data-value=off], .ytp-button-volume[data-value=off]:focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -57px -70px;
}
.ytp-button-volume[data-value=off]:hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -3px -259px;
}
.ytp-button-play, .ytp-embed .ytp-play-button {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -32px -151px;
}
.ytp-button-play:not(.ytp-disabled):hover, .ytp-button-play:not(.ytp-disabled):active, .ytp-button-play:not(.ytp-disabled):focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -32px -124px!important;
}
.ytp-button-pause, .ytp-button-play:not(.ytp-disabled):focus {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -340px;
}
.ytp-button-pause:not(.ytp-disabled):focus, .ytp-button-pause:not(.ytp-disabled):hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) 0 -70px;
}
.ytp-button-replay {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -36px -285px;
}
.ytp-button-replay:not(.ytp-disabled):hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -36px -312px;
}
.ytp-button-stop {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -90px -97px;
}
.ytp-button-stop:not(.ytp-disabled):hover {
background: no-repeat url(https://s.ytimg.com/yt/imgbin/player-dark-vflf2FniH.png) -33px -232px;
}
.ytp-volume-slider-foreground:before {
background:linear-gradient(#290909,#BD2020,#B31E1E,#A71C1C,#901A1A,#6F1313,#444444);
height:7px;
top:4px
}
.ytp-volume-slider-foreground:after {
background:linear-gradient(#050404,#050404,#050404,#050404,#050404,#050404,#444);
height:7px;
top:4px
}
.ytp-volume-slider-foreground {
background:linear-gradient(#fff,#CFCFCF);
border-radius:3px
}
.ytp-button-play, .ytp-volume-control, .ytp-subtitles-button,.ytp-subtitles-button-active, .ytp-settings-button, .ytp-settings-button-active {
border-right: 1px solid #222;
}
.yt-lockup-meta-info li:first-child {
width:100%
}
.yt-ui-ellipsis {
text-overflow:clip
}
.ytp-embed svg {
visibility:hidden}
.ytp-embed button.ytp-fullscreen-button.ytp-button {
width:0!Important;
top:-10px
}
.ytp-embed div.ytp-gradient-top,.ytp-embed .ytp-chrome-top {
display:none
}
.ytp-menuitem {
max-height:26px;
height:26px
}
.ytp-chrome-controls .ytp-button.ytp-youtube-button, .ytp-small-mode .ytp-chrome-controls .ytp-button.ytp-youtube-button, .ytp-exp-bigger-button-like-mobile.ytp-small-mode .ytp-chrome-controls .ytp-button.ytp-youtube-button {
display:none
}
.ytp-embed .ytp-chrome-controls {
max-height:28px!important
}
.ytp-embed .ytp-progress-bar-container {
bottom:32px
}
.ytp-exp-bottom-control-flexbox .ytp-left-controls, :not(.ytp-exp-bottom-control-flexbox) .ytp-right-controls {
margin-top:5px
}
.ytp-embed .ytp-time-display {
height:26px;
line-height:26px
}
html #player.watch-small .html5-video-player:not(.ideal-aspect) .html5-main-video {
max-width:initial!important;
max-height:initial!important
}
.ytp-menu-content {
border-spacing:1px
}
.ytp-menu {
background:#141414;
border-radius:3px 3px 0 0;
padding:0
}
.ytp-drop-down-menu {
display:inline-block!important;
position:relative;
background:none;
border:none;
}
.ytp-drop-down-menu-button {
color:#aaa;
padding:4px 7px
}
.ytp-drop-down-menu-button-selected {
color:#fff;
}
.ytp-drop-down-menu-button-checked .ytp-drop-down-menu-button-check, .ytp-drop-down-menu-button-checked:hover:not(.ytp-disabled) .ytp-drop-down-menu-button-check {
background:none #fff;
border-radius:50%;
height:3px;
width:3px;
margin:0 11px 1px -1px
}
.ytp-drop-down-menu-button-check {
height:3px;
width:3px;
margin:0 11px 1px -1px
}
.ytp-drop-down-menu-button:hover:not(.ytp-disabled) {
background:#601212
}
.ytp-menu-row {
display:inline-block;
vertical-align:top;
box-shadow: 1px 0 0 0 #2b2b2b inset;
border-left: 1px solid #000;
padding:0 3px;
min-height:135px
}
.ytp-menu-row:first-child {
border-left:transparent;
box-shadow:none
}
.ytp-menu-cell {
display:block
}
.ytp-drop-down-label {
display:none
}
.ytp-menu-title {
text-align:left;
padding:4px 7px 4px 16px
}
.ytp-drop-down {
min-width:0!important
}
.ytp-segmented-control {
margin-left:16px
}`;
document.querySelector("head").append(ass);
var playerwasloaded = !1, datawasloaded = !1, playerwasinvoked = !1;
(playerwasloaded = !1), (datawasloaded = !1), (playerwasinvoked = !1);
var streamingdata = {}, dashmanifest = "", rvsdata = "";
function getPlayerData(e) {
return __awaiter(this, void 0, void 0, function* () {
return (yield document.cosmicCat.Ajax.post("/youtubei/v1/player", "videoId: \"" + innertubevideoid + "\",contentCheckOk:true,racyCheckOk:true", "IOS", "16.02"));
});
}
function grabPlayerData() {
return __awaiter(this, void 0, void 0, function* () {
window.location.href.includes("use_legacy_player=1")
? ensureFoo2IsSet().then(function () {
(window.innertuberesponse = ytInitialPlayerResponse),
console.log(innertuberesponse);
try {
(innertuberesponse.streamingData.adaptiveFormats[0].qualityLabel.includes("0s") ||
window.location.href.includes("&only_h=1") ||
0 == v3.config.vp9) &&
murderVp();
}
catch (e) { }
craftVideoStreams();
})
: yield getPlayerData().then((e) => {
window.innertuberesponse = e;
try {
document.documentElement.setAttribute("author", innertuberesponse.videoDetails.channelId),
document.querySelector("body[spftoken]") &&
(document.documentElement.setAttribute("spfinitial" + document.body.getAttribute("spftoken"), ""),
innertuberesponse.streamingData || location.reload(),
setTimeout(function () {
document.documentElement.removeAttribute("spfinitial" + document.body.getAttribute("spftoken"));
}, 1e3));
}
catch (e) { }
console.log("[Vorapis Player] Player API response:\n", innertuberesponse);
try {
(innertuberesponse.streamingData.adaptiveFormats[0].qualityLabel.includes("0s") ||
window.location.href.includes("&only_h=1") ||
0 == v3.config.vp9) &&
murderVp();
}
catch (e) { }
craftVideoStreams();
});
});
}
function craftVideoStreams() {
return __awaiter(this, void 0, void 0, function* () {
function v3CraftDashUrlStreamCompact(e, t, a) {
try {
return e.width
? "init=" +
e.initRange.start +
"-" +
e.initRange.end +
"&size=" +
e.width +
"x" +
e.height +
"&fps=" +
e.fps +
"&lmt=" +
e.lastModified +
"&index=" +
e.indexRange.start +
"-" +
e.indexRange.end +
"&clen=" +
e.contentLength +
"&bitrate=" +
e.bitrate +
"&type=" +
encodeURIComponent(e.mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(e.url) +
"&itag=" +
e.itag
: "init=" +
e.initRange.start +
"-" +
e.initRange.end +
"&lmt=" +
e.lastModified +
"&index=" +
e.indexRange.start +
"-" +
e.indexRange.end +
"&clen=" +
e.contentLength +
"&bitrate=" +
e.bitrate +
"&type=" +
encodeURIComponent(e.mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(e.url) +
"&itag=" +
e.itag;
}
catch (a) {
return e.width
? "init=" +
t.initRange.start +
"-" +
t.initRange.end +
"&size=" +
e.width +
"x" +
e.height +
"&fps=" +
e.fps +
"&lmt=" +
e.lastModified +
"&index=" +
t.indexRange.start +
"-" +
t.indexRange.end +
"&clen=" +
t.contentLength +
"&bitrate=" +
e.bitrate +
"&type=" +
encodeURIComponent(e.mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(e.url) +
"&itag=" +
e.itag
: "init=" +
t.initRange.start +
"-" +
t.initRange.end +
"&lmt=" +
e.lastModified +
"&index=" +
t.indexRange.start +
"-" +
t.indexRange.end +
"&clen=" +
t.contentLength +
"&bitrate=" +
e.bitrate +
"&type=" +
encodeURIComponent(e.mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(e.url) +
"&itag=" +
e.itag;
}
}
try {
streamingdata = ytInitialPlayerResponse.streamingData;
}
catch (e) {
streamingdata = innertuberesponse.streamingData;
}
try {
if (null != streamingdata.dashManifestUrl) {
(dashmanifest = streamingdata.dashManifestUrl),
(window.usingDashMpd = !0),
(window.wasVideo = !0);
var mse = window.MediaSource;
if (mse) {
var nativeITS = mse.isTypeSupported.bind(mse);
mse.isTypeSupported = ourITS(nativeITS);
}
function ourITS(e) {
return function (t) {
return void 0 === t || t.toLowerCase().indexOf("vp9") > -1
? ""
: e(t);
};
}
}
else
(window.usingDashMpd = !1),
"/watch" == window.location.pathname && (window.wasVideo = !0);
}
catch (e) {
console.error(e);
return void (window.location.pathname.includes("/watch") && buildErrorScreen());
}
try {
var adaptivefmts = innertuberesponse.streamingData.adaptiveFormats;
}
catch (e) {
console.error("No fmt\n", e);
var adaptivefmts = streamingdata.adaptiveFormats;
}
var craftedadaptivefmts = "", needscut = !1;
if (void 0 === streamingdata.hlsManifestUrl ||
void 0 === streamingdata.dashManifestUrl)
try {
if ("" == dashmanifest) {
for (var i = 0, j = adaptivefmts.length; i < j; i++) {
try {
if (0 == adaptivefmts[i].audioTrack.audioIsDefault) {
//needscut = !0;
continue;
}
}
catch (e) { }
"UNDEFINED" !=
v3CraftDashUrlStreamCompact(adaptivefmts[i], adaptivefmts[0], 1) &&
(i == j - 1
? (craftedadaptivefmts += v3CraftDashUrlStreamCompact(adaptivefmts[i], adaptivefmts[0], 1))
: (craftedadaptivefmts +=
v3CraftDashUrlStreamCompact(adaptivefmts[i], adaptivefmts[0], 1) + ","));
}
needscut &&
(craftedadaptivefmts = craftedadaptivefmts.substring(0, craftedadaptivefmts.length - 1));
}
}
catch (e) {
console.error("[Vorapis Player]\n", e);
}
document.cosmicCat.Utils.waitForElm(".player-root").then(function () {
try {
try {
if (1 == yt.config_.LOGGED_IN) {
var e = !1;
try {
ytInitialData.contents.twoColumnWatchNextResults.secondaryResults
.secondaryResults.results[1].itemSectionRenderer.contents
.length && (e = !0);
}
catch (e) { }
try {
ytInitialData.contents.twoColumnWatchNextResults.secondaryResults
.secondaryResults.results.length && (e = !0);
}
catch (e) { }
try {
ytInitialData.contents.twoColumnWatchNextResults.results.results.contents
.find(function (e) {
try {
return !!e.videoSecondaryInfoRenderer;
}
catch (e) {
return !1;
}
})
.videoSecondaryInfoRenderer.metadataRowContainer.metadataRowContainerRenderer.rows[0].metadataRowRenderer.contents[0].runs[0].text.includes("Age-restricted") &&
!e &&
v3AgeRestrictFriend();
}
catch (e) { }
waitForElm2("#eow-description").then(function () {
"" == document.querySelector("#eow-description").innerText &&
"" != innertuberesponse.videoDetails.shortDescription &&
(document.querySelector("#eow-description").innerText =
innertuberesponse.videoDetails.shortDescription);
});
}
}
catch (e) {
console.error("[Vorapis Player]\n", e);
}
function t(e) {
for (var t = e.split(":"), a = 0, n = 1; t.length > 0;)
(a += n * parseInt(t.pop(), 10)), (n *= 60);
return a;
}
var a;
document.querySelector("html[c3]") && v3ChannelFriend(),
(a =
void 0 !==
ytInitialData.contents.twoColumnWatchNextResults.secondaryResults
.secondaryResults.results[1].itemSectionRenderer
? ytInitialData.contents.twoColumnWatchNextResults
.secondaryResults.secondaryResults.results[1]
.itemSectionRenderer.contents
: ytInitialData.contents.twoColumnWatchNextResults
.secondaryResults.secondaryResults.results);
var n = 0;
for (var i = 0, j = a.length; i < j; i++)
if (n < 12 && a[i].compactVideoRenderer) {
var r = 0;
try {
r = a[i].compactVideoRenderer.viewCountText.simpleText
.split(" ")[0]
.replace(new RegExp(",", "g"), "");
}
catch (e) { }
var o = "";
try {
o = t(a[i].compactVideoRenderer.lengthText.simpleText);
}
catch (e) { }
(rvsdata +=
"title=" +
encodeURIComponent(a[i].compactVideoRenderer.title.simpleText).replace(new RegExp("%20", "g"), "+") +
"&author=" +
encodeURIComponent(a[i].compactVideoRenderer.shortBylineText.runs[0].text).replace(new RegExp("%20", "g"), "+") +
"&view_count=" +
r +
"&length_seconds=" +
o +
"&id=" +
a[i].compactVideoRenderer.videoId),
11 != n && (rvsdata += ","),
n++;
}
}
catch (e) {
console.error("[Vorapis Player]\n", e);
}
craftVarYtPlayer(craftedadaptivefmts);
});
});
}
function craftVarYtPlayer(e) {
var _a, _b, _c, _d;
var t = "";
try {
t = innertuberesponse.storyboards.playerStoryboardSpecRenderer.spec;
}
catch (e) {
try {
t =
ytInitialPlayerResponse.storyboards.playerStoryboardSpecRenderer.spec;
}
catch (e) {
console.error(e);
}
}
const a = { config: {
url: "https://s.ytimg.com/yts/swfbin/player-vfl8Mj1Eu/watch_as3.swf",
urlV8: "https://s.ytimg.com/yts/swfbin/player-vfl8Mj1Eu/cps.swf",
urlV9As2: "https://s.ytimg.com/yts/swfbin/player-vfl8Mj1Eu/cps.swf",
args: {
author: innertuberesponse.videoDetails.author,
dashmpd: dashmanifest,
focEnabled: "1",
adaptive_fmts: "",
account_playback_token: "",
enablecsi: "0",
length_seconds: innertuberesponse.videoDetails.lengthSeconds,
ytfocEnabled: "1",
remarketing_url: "",
cos: "Windows",
uid: "",
iv_invideo_url: "",
idpj: "0",
sourceid: "y",
vid: innertuberesponse.videoDetails.videoId,
watermark: ",https://s.ytimg.com/yts/img/watermark/youtube_watermark-vflHX6b6E.png,https://s.ytimg.com/yts/img/watermark/youtube_hd_watermark-vflAzLcD6.png",
avg_rating: "",
fexp: "908547,914099,927622,930666,930672,932404,934040,940247,940642,947209,947215,949424,951701,952302,952901,953000,953912,957103,957201,958600",
host_language: "en",
iv_load_policy: "1",
token: "1",
loaderUrl: "https://www.youtube.com/watch?v=" + innertuberesponse.videoDetails.videoId,
ptk: "ea",
baseUrl: "https://googleads.g.doubleclick.net/pagead/viewthroughconversion/962985656/",
cosver: "6.2",
t: "1",
oid: "",
cbrver: "2.20230331.00.00",
plid: "",
ptchn: "",
dash: "1",
no_get_video_log: "1",
sdetail: "p:/embed/" + innertuberesponse.videoDetails.videoId,
tmi: "1",
storyboard_spec: t,
vq: "auto",
atc: "",
of: "",
allow_embed: "1",
url_encoded_fmt_stream_map: "",
aid: "",
ucid: innertuberesponse.videoDetails.channelId,
cr: "RO",
timestamp: "1414688781",
iv_module: "https://s.ytimg.com/yts/swfbin/player-vfl8Mj1Eu/iv_module.swf",
rmktEnabled: "1",
probe_url: "https://www.youtube.com/embed/" + innertuberesponse.videoDetails.videoId,
video_id: innertuberesponse.videoDetails.videoId,
title: innertuberesponse.videoDetails.title,
cl: "78766649",
eventid: "",
csi_page_type: "watch,watch7",
hl: "en_US",
iv3_module: "1",
sw: "0.1",
fmt_list: "22/1280x720/9/0/115,18/640x360/9/0/115,17/256x144/99/1/0",
cbr: "WEB",
ytfocHistoryEnabled: "0",
referrer: "https://www.youtube.com/embed/" + innertuberesponse.videoDetails.videoId,
allow_ratings: "1",
enablejsapi: 0,
pltype: "content",
keywords: innertuberesponse.videoDetails.title,
ldpj: "0",
c: "WEB",
view_count: innertuberesponse.videoDetails.viewCount
},
assets: {
css: "//s.ytimg.com/yts/cssbin/www-player-vfluwFMix.css",
js: "//s.ytimg.com/yts/jsbin/html5player-en_US-vfln6g5Eq/html5player.js",
html: "//raw.githubusercontent.com/cosmic-cat-yt/Cosmic-Cat/main/html5_player_template"
},
attrs: {
id: "movie_player"
},
params: {
allowfullscreen: "true",
allowscriptaccess: "always",
bgcolor: "#000000"
},
minVersion: "8.0.0",
fallback: null,
fallbackMessage: null,
html5: !0,
disable: {},
loaded: !0,
messages: {
player_fallback: [
'Adobe Flash Player or an HTML5 supported browser is required for video playback.<br><a href="https://get.adobe.com/flashplayer/">Get the latest Flash Player </a><br><a href="/html5">Learn more about upgrading to an HTML5 browser</a>'
]
}
} };
(a.config.args.adaptive_fmts = e), (window.ytplayer = a);
var n = "";
if (void 0 === streamingdata.hlsManifestUrl) {
try {
for (var i = 0, j = innertuberesponse.streamingData.formats.length; i < j; i++)
(n +=
"fallback_host=" +
innertuberesponse.streamingData.formats[i].url
.split("://")[1]
.split(".com")[0] +
".com&type=" +
encodeURIComponent(innertuberesponse.streamingData.formats[i].mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(innertuberesponse.streamingData.formats[i].url) +
"&quality=" +
innertuberesponse.streamingData.formats[i].quality +
"&itag=" +
innertuberesponse.streamingData.formats[i].itag),
i < parseInt(innertuberesponse.streamingData.formats.length - 1) &&
(n += ",");
}
catch (_e) {
// Try again with adaptiveFormats instead.
try {
for (var i = 0, j = innertuberesponse.streamingData.adaptiveFormats.length; i < j; i++)
(n +=
"fallback_host=" +
innertuberesponse.streamingData.adaptiveFormats[i].url
.split("://")[1]
.split(".com")[0] +
".com&type=" +
encodeURIComponent(innertuberesponse.streamingData.adaptiveFormats[i].mimeType).replace("%20", "+") +
"&url=" +
encodeURIComponent(innertuberesponse.streamingData.adaptiveFormats[i].url) +
"&quality=" +
innertuberesponse.streamingData.adaptiveFormats[i].quality +
"&itag=" +
innertuberesponse.streamingData.adaptiveFormats[i].itag),
i < parseInt(innertuberesponse.streamingData.adaptiveFormats.length - 1) &&
(n += ",");
}
catch (e) {
console.error("[Vorapis Player] could not craft legacy stream url", e);
}
}
ytplayer.config.args.url_encoded_fmt_stream_map = n;
}
else {
(ytplayer.config.args.live_chunk_readahead = 0),
(ytplayer.config.args.live_playback = 1),
(ytplayer.config.args.livestream = 0),
(ytplayer.config.args.hlsdvr = 0),
(ytplayer.config.args.hlsvp = streamingdata.hlsManifestUrl),
(ytplayer.config.args.fmt_list = "");
try {
ytplayer.config.args.live_storyboard_spec =
innertuberesponse.storyboards.playerLiveStoryboardSpecRenderer.spec;
}
catch (e) { }
(ytplayer.config.args.instream = !0),
(ytplayer.config.args.instream_long = !0),
(ytplayer.config.args.streaminglib_module = 1),
(ytplayer.config.args.pltype = "contentlive"),
(ytplayer.config.args.ps = "live"),
(ytplayer.config.args.probe_url = ""),
(ytplayer.config.args.enable_cardio = 0),
(ytplayer.config.args.enable_cardio_before_playback = 0);
}
innertuberesponse.captions &&
(ytplayer.config.args.ttsurl =
document.cosmicCat.Channels.isChannelsPage() ?
"" :
(_d = (_c = (_b = (_a = innertuberesponse.captions) === null || _a === void 0 ? void 0 : _a.playerCaptionsTracklistRenderer) === null || _b === void 0 ? void 0 : _b.captionTracks) === null || _c === void 0 ? void 0 : _c.find(a => a.languageCode == "en" && a.kind !== "asr")) === null || _d === void 0 ? void 0 : _d.baseUrl),
(ytplayer.config.args.rvs = rvsdata),
(datawasloaded = !0),
playerwasloaded && !playerwasinvoked && invokePlayer(),
console.log("[Vorapis Player] success to load player.\n", ytplayer, playerwasloaded, playerwasinvoked);
}
function invokePlayer() {
yt.player.Application.create("player-api", ytplayer.config);
let a = document.querySelector("#movie_player");
document.querySelector(".player-root").append(a);
try {
document.querySelector("#player.skeleton.flexy").remove();
}
catch (_a) { }
$(document).on('click', '.ytp-size-toggle-large, .ytp-size-button.toggled', function (e) {
if (e.target.classList.contains("ytp-size-button"))
e.target.classList.remove("toggled");
document.querySelector('#watch-container').classList.remove("watch-wide");
document.querySelector('#watch-video').classList.add('small');
document.querySelector('#watch-video').classList.remove('large');
setTimeout(function () { if (document.querySelector('.watch-playlist-collapsed'))
document.querySelector('#player').classList.remove('watch-playlist-collapsed'); }, 1);
});
$(document).on('click', '.ytp-size-toggle-small, .ytp-size-button:not(.toggled)', function (e) {
if (e.target.classList.contains("ytp-size-button"))
e.target.classList.add("toggled");
if (document.querySelector('.watch-playlist'))
document.querySelector('#player').classList.add('watch-playlist-collapsed');
document.querySelector('#watch-container').classList.add("watch-wide");
setTimeout(function () {
document.querySelector('#watch-video').classList.remove('small');
document.querySelector('#watch-video').classList.add('large');
}, 300);
});
}
function buildErrorScreen() {
console.log("build error screen"),
document.cosmicCat.Utils.waitForElm("#player-api").then(function (e) {
var t = "Video unavailable";
try {
(t = innertuberesponse.playabilityStatus.reason),
innertuberesponse.playabilityStatus.reason
.toLocaleLowerCase()
.includes("premieres") &&
document
.querySelector("body")
.classList.add("using-innertube-heartbeat"),
document.querySelector("body").setAttribute("hbr", "wp"),
document
.querySelector("body")
.setAttribute("hba", innertuberesponse.heartbeatParams.heartbeatServerData);
}
catch (e) { }
try {
t =
innertuberesponse.playabilityStatus.errorScreen
.playerErrorMessageRenderer.subreason.simpleText;
}
catch (e) { }
try {
null == t && (t = innertuberesponse.playabilityStatus.reason);
}
catch (e) { }
t.toLowerCase().includes("confirm")
? (document.querySelector("#player-api").innerHTML =
'<div id="player-unavailable" class=" with-background player-width player-height player-unavailable ">\n <img class="icon meh" src="//s.ytimg.com/yts/img/meh7-vflGevej7.png" alt="">\n <div class="content">\n <h1 id="unavailable-message" class="message">\n Content Warning\n\n </h1>\n <div id="unavailable-submessage" class="submessage">\n <div id="watch7-player-age-gate-content">\n <p>This video may be inappropriate for some users.</p>\n\n <button class=" yt-uix-button yt-uix-button-primary yt-uix-button-size-default" type="button" href="https://accounts.google.com/ServiceLogin?service=youtube&continue=http%3A%2F%2Fwww.youtube.com%2Fsignin%3Faction_handle_signin%3Dtrue%26app%3Ddesktop%26feature%3Dverify_age_streamlined%26hl%3Den%26next%3D%252Fwatch%253Fv%253DMlPh_ycy62s&passive=true&shdf=Cp4BCxILZGVzY3JpcHRpb24aMkl0IHdvdWxkIGJlIGF3ZXNvbWUgaWYgeW91IGNvdWxkIHBsZWFzZSBTdWJzY3JpLi4uDAsSBnJlYXNvbhoBMwwLEgd2aWRlb0lkGgoyNDA0OTA3MzIwDAsSCnZpZGVvVGl0bGUaJ0hhcmxlbSBTaGFrZSBDb21waWxhdGlvbiEgKEJFU1QgVklERU9TKQwSB3lvdXR1YmUaBFNIQTEiFPT6MQfKLgISJ5I3OxthncBZEblbKAEyFP95e22CYyYjv222-YZ0VSobO--X&ltmpl=verifyage&hl=en" onclick=";window.location.href=this.getAttribute(\'href\');return false;" role="button"><span class="yt-uix-button-content">Sign in to confirm your age </span></button>\n </div>\n\n </div>\n </div>\n\n\n </div>')
: (document.querySelector("#player-api").innerHTML =
'<div id="player-unavailable" class=" player-width player-height player-unavailable ">\n <img class="icon meh" src="//s.ytimg.com/yts/img/meh7-vflGevej7.png" alt="">\n <div class="content">\n <h1 id="unavailable-message" class="message">\n ' +
t +
'\n\n </h1>\n <div id="unavailable-submessage" class="submessage">\nSorry about that.\n </div>\n </div>\n\n\n </div>'),
"CONTENT_CHECK_REQUIRED" ==
innertuberesponse.playabilityStatus.status &&
"AGE_CHECK_REQUIRED" ==
innertuberesponse.playabilityStatus.status &&
(document.querySelector("#player-api").innerHTML =
'<div id="player-unavailable" class=" with-background player-width player-height player-unavailable ">\n <img class="icon meh" src="//s.ytimg.com/yts/img/meh7-vflGevej7.png" alt="">\n <div class="content">\n <h1 id="unavailable-message" class="message">\n Content Warning\n\n </h1>\n <div id="unavailable-submessage" class="submessage">\n <div id="watch7-player-age-gate-content">\n <p>This video may be inappropriate for some users.</p>\n\n <button class=" yt-uix-button yt-uix-button-primary yt-uix-button-size-default" type="button" onclick="v3ConfirmFriend();" role="button"><span class="yt-uix-button-content">I understand and wish to proceed </span></button>\n </div>\n\n </div>\n </div>\n\n\n </div>');
});
}
mission && null == yt.config_.INNERTUBE_API_KEY && location.reload(),
grabPlayerData();
}
var img$1 = "";
var img = "";
class Data {
constructor() {
this.version = 1;
this.loggedin = false;
this.homeCategories = [
"trending",
"popular",
"music",
"live",
"gadgets",
"news",
"sports",
"education",
"howto"
];
this.darkyoutubelogo = img$1;
this.i18nfolder = "https://raw.githubusercontent.com/cosmic-cat-yt/cosmic-cat-i18n/main/i18n/";
this.darknoisebg = img;
this.loginUrl = "https://accounts.google.com/ServiceLogin?service=youtube&uilel=3&passive=true&continue=https%3A%2F%2Fwww.youtube.com%2Fsignin%3Faction_handle_signin%3Dtrue%26app%3Ddesktop%26hl%3Den%26next%3Dhttps%253A%252F%252Fwww.youtube.com%252F&hl=en&ec=65620";
this.lang = {
"af": "Afrikaans",
"ar": "",
"az": "Azərbaycan",
"bs": "Bosanski",
"ca": "Català",
"cs": "Čeština",
"da": "Dansk",
"de": "Čeština",
"en": "English",
"en-GB": "English (UK)",
"en-IN": "English (India)",
"es": "Español (España)",
"es-419": "Español (España)",
"es-US": "Español (US)",
"et": "Eesti",
"eu": "Euskara",
"fa": "",
"fi": "Suomi",
"fil": "Filipino",
"fr": "Français",
"fr-CA": "Français (Canada)",
"gl": "Galego",
"hr": "Hrvatski",
"hu": "Magyar",
"ja": "日本語",
"pl": "Polski"
};
}
}
let Settings$1 = class Settings {
constructor(cc) {
this.cc = null;
this.cc = cc;
}
toggleOption(a) {
if (a.checked !== undefined) {
a.value = a.checked ? 1 : 0;
}
this.cc.Storage.add(a.dataset.storage, a.value);
this.cc.Alert(0, `Changed setting ${a.dataset.storage} to ${a.value}`);
(this.cc.Settings[a.dataset.action] || this.cc.null)();
}
toggleTab(a) {
document.querySelector(".individual-feed.selected").classList.add("hid");
document.querySelector(".individual-feed.selected").classList.remove("selected");
document.querySelector(".guide-item-container.selected-child").classList.remove("selected-child");
document.querySelector(".guide-item.selected").classList.remove("selected");
a.classList.add("selected-child");
a.children[0].classList.add("selected");
document.querySelector("#feed-main-" + a.children[0].dataset.feedName).classList.remove("hid");
document.querySelector("#feed-main-" + a.children[0].dataset.feedName).classList.add("selected");
}
toggleDarkTheme(a) {
if (document.querySelector("#www-yt-dark")) {
document.querySelector("#www-yt-dark").remove();
}
else {
const a = document.createElement("style");
a.setAttribute("id", "www-yt-dark");
a.innerText = OBJ_STYLE_DARK;
document.head.append(a);
}
}
};
class Ajax {
constructor(cc) {
this.cc = cc;
}
post(url, params, name, version) {
return __awaiter(this, void 0, void 0, function* () {
let Authorization = "";
params = params ? params + "," : "";
let body = `{${params} context: {client: {"clientName": "${name}", "clientVersion": "${version}", "hl": "en"}}}`;
// Check if logged in
if (this.cc.Utils.getCookie("SAPISID")) {
Authorization = yield this.cc.Account.getSApiSidHash();
}
// Fetch
const response = yield fetch("https://www.youtube.com" + url + "?key=AIzaSyAO_FJ2SlqU8Q4STEHLGCilw_Y9_11qcW8&prettyPrint=false", {
method: "POST",
headers: {
"Content-Type": "application/json",
"X-Goog-AuthUser": "1",
"X-Goog-Visitor-Id": "",
"X-Youtube-Client-Version": "17.33",
"X-Youtube-Bootstrap-Logged-In": "true",
"X-Youtube-Client-Name": "1",
"X-Origin": "https://www.youtube.com",
Authorization
},
body: body
})
.catch(err => {
this.cc.Alert(1, "Cosmic Cat Error: Failed to fetch resource. Check console for more details.");
console.error("[Ajax] Failed to fetch resource at \"" + url + "\":\n", err);
});
return response.json();
});
}
Fetch(url, callback) {
return __awaiter(this, void 0, void 0, function* () {
if (!url)
return console.error("[Ajax] Parameters must be supplied!");
return yield fetch(url).then(a => this.cc.Utils.convertXHRtoJSON(a.text())).then(res => (callback) ? callback(res) : res).catch(e => {
this.cc.Alert(1, "Cosmic Cat Error: Failed to fetch resource. Check console for more details.");
console.error("[Ajax] Failed to fetch resource at \"" + url + "\":\n", e);
});
});
}
}
class Account {
constructor(cc) {
this.cc = cc;
}
getSApiSidHash() {
return __awaiter(this, void 0, void 0, function* () {
function sha1(str) {
return __awaiter(this, void 0, void 0, function* () {
const buf = yield window.crypto.subtle.digest("SHA-1", new TextEncoder().encode(str));
return Array.prototype.map.call(new Uint8Array(buf), x => (('00' + x.toString(16)).slice(-2))).join('');
});
}
const MS = Date.now().toString();
const TIMESTAMP = MS.substring(0, MS.length - 3);
const digest = yield sha1(`${TIMESTAMP} ${this.cc.Utils.getCookie("SAPISID")} https://www.youtube.com`);
return `SAPISIDHASH ${TIMESTAMP}_${digest}`;
});
}
fetch() {
return __awaiter(this, void 0, void 0, function* () {
let isLoggedIn = yield fetch("/getAccountSwitcherEndpoint").then(re => re.text()).then(re => {
return JSON.parse(re.slice(5));
}).catch(err => console.error("[Accounts] Failed to fetch account data:\n", err));
let BOOL_LOGIN = false;
try {
BOOL_LOGIN = !isLoggedIn.ok;
}
catch (_a) {
BOOL_LOGIN = false;
}
if (BOOL_LOGIN == true) {
this.cc.Account.updateLogin(isLoggedIn);
}
});
}
updateLogin(logInData) {
var _a;
let popup = logInData.data.actions[0].getMultiPageMenuAction.menu.multiPageMenuRenderer.sections[0].accountSectionListRenderer;
let accountItem = (_a = popup.contents[0].accountItemSectionRenderer.contents.find(a => a.accountItem.isSelected == true)) === null || _a === void 0 ? void 0 : _a.accountItem;
let google = popup.header.googleAccountHeaderRenderer;
this.cc.data.loggedin = true;
this.cc.Storage.add("accountInfo", {
name: accountItem.accountName.simpleText,
pfp: accountItem.accountPhoto.thumbnails[0].url,
link: accountItem.navigationEndpoint,
email: google.email.simpleText
});
}
checkLogin() {
fetch("/getAccountSwitcherEndpoint").then(re => re.text()).then(re => {
var _a;
var a = JSON.parse(re.slice(5));
var b = a.data.actions[0].getMultiPageMenuAction.menu.multiPageMenuRenderer.sections[0].accountSectionListRenderer;
if (this.cc.Storage.get("accountInfo").value.name !== ((_a = b.contents[0].accountItemSectionRenderer.contents.find(a => a.accountItem.isSelected == true)) === null || _a === void 0 ? void 0 : _a.accountItem.accountName.simpleText)) {
this.cc.Account.updateLogin(a);
}
}).catch(err => console.error(err));
}
isLoggedIn() {
if (!this.cc.Utils.getCookie("SAPISID") && this.cc.Storage.get("accountInfo").exists) {
alert("Cosmic Cat\n\nUnsafe_logout_detected:\nDO NOT TYPE \"/logout\" INTO THE URL BAR!\nTHIS WILL CAUSE STUFF TO BREAK!");
this.cc.Account.logout();
return false;
}
return this.cc.Storage.get("accountInfo").exists;
}
logout() {
this.cc.Storage.remove("accountInfo");
(this.cc.Storage.get("greeting_feed").value == "subscriptions") && this.cc.Storage.add("greeting_feed", "youtube");
window.location.href = "/logout?cleared_storage=1";
}
}
class Utils {
constructor(cc) {
this.browseTabs = {
find: (data, param) => {
try {
return data.contents.twoColumnBrowseResultsRenderer.tabs.find(b => b.tabRenderer.endpoint.commandMetadata.webCommandMetadata.url.split("/")[3] === param);
}
catch (_b) {
try {
return data.contents.twoColumnBrowseResultsRenderer.tabs.find(b => b.tabRenderer.endpoint.commandMetadata.webCommandMetadata.url.split("/")[2] === param);
}
catch (_c) {
return {};
}
}
},
content: (data) => {
var _b, _c, _d, _e, _f;
try {
return ((_b = data.sectionListRenderer) === null || _b === void 0 ? void 0 : _b.contents) || ((_d = (_c = data.tabRenderer.content) === null || _c === void 0 ? void 0 : _c.richGridRenderer) === null || _d === void 0 ? void 0 : _d.contents) || ((_f = (_e = data.tabRenderer.content) === null || _e === void 0 ? void 0 : _e.sectionListRenderer) === null || _f === void 0 ? void 0 : _f.contents);
}
catch (_g) {
return {};
}
}
};
this.Sort = {
channelData: (data) => {
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21;
if (!data)
return {};
let _description = ((_b = data.descriptionSnippet) === null || _b === void 0 ? void 0 : _b.runs) || [];
let description = "";
for (const snippet in _description) {
description += _description[snippet].text;
}
console.log(data);
return {
id: data.channelId || ((_d = (_c = data.subscribeButton) === null || _c === void 0 ? void 0 : _c.subscribeButtonRenderer) === null || _d === void 0 ? void 0 : _d.channelId),
name: ((_e = data.title) === null || _e === void 0 ? void 0 : _e.simpleText) || data.title,
gameBy: (_g = (_f = data.metadata) === null || _f === void 0 ? void 0 : _f.runs) === null || _g === void 0 ? void 0 : _g[0].text,
tag: (_m = (_l = (_k = (_j = (_h = data.channelHandleText) === null || _h === void 0 ? void 0 : _h.runs) === null || _j === void 0 ? void 0 : _j[0]) === null || _k === void 0 ? void 0 : _k.text) === null || _l === void 0 ? void 0 : _l.split("@")) === null || _m === void 0 ? void 0 : _m[1],
url: data.canonicalChannelUrl || ((_p = (_o = data.navigationEndpoint) === null || _o === void 0 ? void 0 : _o.browseEndpoint) === null || _p === void 0 ? void 0 : _p.canonicalBaseUrl),
avatar: ((_s = (_r = (_q = data.avatar) === null || _q === void 0 ? void 0 : _q.thumbnails) === null || _r === void 0 ? void 0 : _r[0]) === null || _s === void 0 ? void 0 : _s.url) || ((_v = (_u = (_t = data.thumbnail) === null || _t === void 0 ? void 0 : _t.thumbnails) === null || _u === void 0 ? void 0 : _u[0]) === null || _v === void 0 ? void 0 : _v.url) || ((_y = (_x = (_w = data.boxArt) === null || _w === void 0 ? void 0 : _w.thumbnails) === null || _x === void 0 ? void 0 : _x[0]) === null || _y === void 0 ? void 0 : _y.url),
links: data.links,
bannerBg: (_1 = (_0 = (_z = data.tvBanner) === null || _z === void 0 ? void 0 : _z.thumbnails) === null || _0 === void 0 ? void 0 : _0[4]) === null || _1 === void 0 ? void 0 : _1.url,
subscriberCount: this.cc.Utils.deabreviateCnt(((_4 = (_3 = (_2 = data.subscriberCountText) === null || _2 === void 0 ? void 0 : _2.simpleText) === null || _3 === void 0 ? void 0 : _3.split(" ")) === null || _4 === void 0 ? void 0 : _4[0]) || ((_7 = (_6 = (_5 = data.subtitle) === null || _5 === void 0 ? void 0 : _5.simpleText) === null || _6 === void 0 ? void 0 : _6.split(" ")) === null || _7 === void 0 ? void 0 : _7[0]) || "0"),
videos: ((_9 = (_8 = data.videoCountText) === null || _8 === void 0 ? void 0 : _8.runs) === null || _9 === void 0 ? void 0 : _9[1]) && (((_11 = (_10 = data.videoCountText) === null || _10 === void 0 ? void 0 : _10.runs) === null || _11 === void 0 ? void 0 : _11[0].text) + ((_13 = (_12 = data.videoCountText) === null || _12 === void 0 ? void 0 : _12.runs) === null || _13 === void 0 ? void 0 : _13[1].text)),
fields: {
views: this.cc.Utils.deabreviateCnt((_16 = (_15 = (_14 = data.viewCountText) === null || _14 === void 0 ? void 0 : _14.simpleText) === null || _15 === void 0 ? void 0 : _15.split(" ")) === null || _16 === void 0 ? void 0 : _16[0]) || "0",
joined: (_19 = (_18 = (_17 = data.joinedDateText) === null || _17 === void 0 ? void 0 : _17.runs) === null || _18 === void 0 ? void 0 : _18[1]) === null || _19 === void 0 ? void 0 : _19.text,
country: (_20 = data.country) === null || _20 === void 0 ? void 0 : _20.simpleText,
description: (((_21 = data.description) === null || _21 === void 0 ? void 0 : _21.simpleText) || description).replace(/(?:\r\n|\r|\n)/g, "<br/>")
}
};
},
videoData: (da) => {
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21, _22, _23, _24, _25, _26, _27, _28, _29, _30, _31, _32, _33, _34, _35, _36, _37, _38, _39, _40, _41, _42, _43, _44, _45, _46, _47, _48, _49, _50, _51, _52, _53, _54, _55, _56, _57, _58, _59, _60, _61, _62, _63, _64, _65, _66, _67, _68, _69, _70, _71, _72, _73, _74, _75, _76, _77, _78, _79, _80, _81, _82, _83, _84, _85, _86, _87, _88, _89, _90, _91, _92, _93;
if (!da)
return {};
let _description = ((_d = (_c = (_b = da.detailedMetadataSnippets) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.snippetText) === null || _d === void 0 ? void 0 : _d.runs) || ((_e = da.descriptionSnippet) === null || _e === void 0 ? void 0 : _e.runs) || ((_f = da.description) === null || _f === void 0 ? void 0 : _f.runs) || ((_g = da.videoDetails) === null || _g === void 0 ? void 0 : _g.shortDescription) || [];
if (da.attributedDescription)
_description = (_h = this.cc.Utils.convertDescription(da.attributedDescription)) === null || _h === void 0 ? void 0 : _h.runs;
let description = "";
for (const snippet in _description) {
if (_description[snippet].navigationEndpoint) {
let href = (_l = (_k = (_j = _description[snippet].navigationEndpoint) === null || _j === void 0 ? void 0 : _j.commandMetadata) === null || _k === void 0 ? void 0 : _k.webCommandMetadata) === null || _l === void 0 ? void 0 : _l.url;
description += `<a href="${href}">${_description[snippet].text}</a>`;
}
else {
description += _description[snippet].text;
}
}
description = description.replace(/(?:\r\n|\r|\n)/g, '<br/>');
return {
owner: {
name: ((_r = (_q = (_p = (_o = (_m = da.owner) === null || _m === void 0 ? void 0 : _m.videoOwnerRenderer) === null || _o === void 0 ? void 0 : _o.title) === null || _p === void 0 ? void 0 : _p.runs) === null || _q === void 0 ? void 0 : _q[0]) === null || _r === void 0 ? void 0 : _r.text) || ((_u = (_t = (_s = da.bylineText) === null || _s === void 0 ? void 0 : _s.runs) === null || _t === void 0 ? void 0 : _t[0]) === null || _u === void 0 ? void 0 : _u.text) || ((_x = (_w = (_v = da.shortBylineText) === null || _v === void 0 ? void 0 : _v.runs) === null || _w === void 0 ? void 0 : _w[0]) === null || _x === void 0 ? void 0 : _x.text) || ((_0 = (_z = (_y = da.ownerText) === null || _y === void 0 ? void 0 : _y.runs) === null || _z === void 0 ? void 0 : _z[0]) === null || _0 === void 0 ? void 0 : _0.text) || ((_1 = da.videoDetails) === null || _1 === void 0 ? void 0 : _1.author) || ((_6 = (_5 = (_4 = (_3 = (_2 = da.owner) === null || _2 === void 0 ? void 0 : _2.videoOwnerRenderer) === null || _3 === void 0 ? void 0 : _3.title) === null || _4 === void 0 ? void 0 : _4.runs) === null || _5 === void 0 ? void 0 : _5[0]) === null || _6 === void 0 ? void 0 : _6.text),
url: ((_10 = (_9 = (_8 = (_7 = da.owner) === null || _7 === void 0 ? void 0 : _7.videoOwnerRenderer) === null || _8 === void 0 ? void 0 : _8.navigationEndpoint) === null || _9 === void 0 ? void 0 : _9.browseEndpoint) === null || _10 === void 0 ? void 0 : _10.canonicalBaseUrl) || ((_15 = (_14 = (_13 = (_12 = (_11 = da.bylineText) === null || _11 === void 0 ? void 0 : _11.runs) === null || _12 === void 0 ? void 0 : _12[0]) === null || _13 === void 0 ? void 0 : _13.navigationEndpoint) === null || _14 === void 0 ? void 0 : _14.browseEndpoint) === null || _15 === void 0 ? void 0 : _15.canonicalBaseUrl) || ((_20 = (_19 = (_18 = (_17 = (_16 = da.shortBylineText) === null || _16 === void 0 ? void 0 : _16.runs) === null || _17 === void 0 ? void 0 : _17[0]) === null || _18 === void 0 ? void 0 : _18.navigationEndpoint) === null || _19 === void 0 ? void 0 : _19.browseEndpoint) === null || _20 === void 0 ? void 0 : _20.canonicalBaseUrl) || ((_25 = (_24 = (_23 = (_22 = (_21 = da.longBylineText) === null || _21 === void 0 ? void 0 : _21.runs) === null || _22 === void 0 ? void 0 : _22[0]) === null || _23 === void 0 ? void 0 : _23.navigationEndpoint) === null || _24 === void 0 ? void 0 : _24.browseEndpoint) === null || _25 === void 0 ? void 0 : _25.canonicalBaseUrl),
id: ((_26 = da.videoDetails) === null || _26 === void 0 ? void 0 : _26.channelId) || ((_30 = (_29 = (_28 = (_27 = da.owner) === null || _27 === void 0 ? void 0 : _27.videoOwnerRenderer) === null || _28 === void 0 ? void 0 : _28.navigationEndpoint) === null || _29 === void 0 ? void 0 : _29.browseEndpoint) === null || _30 === void 0 ? void 0 : _30.browseId) || ((_35 = (_34 = (_33 = (_32 = (_31 = da.shortBylineText) === null || _31 === void 0 ? void 0 : _31.runs) === null || _32 === void 0 ? void 0 : _32[0]) === null || _33 === void 0 ? void 0 : _33.navigationEndpoint) === null || _34 === void 0 ? void 0 : _34.browseEndpoint) === null || _35 === void 0 ? void 0 : _35.browseId),
icon: (_40 = (_39 = (_38 = (_37 = (_36 = da.channelThumbnailSupportedRenderers) === null || _36 === void 0 ? void 0 : _36.channelThumbnailWithLinkRenderer) === null || _37 === void 0 ? void 0 : _37.thumbnail) === null || _38 === void 0 ? void 0 : _38.thumbnails) === null || _39 === void 0 ? void 0 : _39[0]) === null || _40 === void 0 ? void 0 : _40.url
},
time: ((_42 = (_41 = da.thumbnailOverlays) === null || _41 === void 0 ? void 0 : _41.find(c => c.thumbnailOverlayTimeStatusRenderer)) === null || _42 === void 0 ? void 0 : _42.thumbnailOverlayTimeStatusRenderer.text.simpleText) || ((_48 = (_47 = (_46 = (_45 = (_44 = (_43 = da.thumbnailOverlays) === null || _43 === void 0 ? void 0 : _43.find(c => c.thumbnailOverlayTimeStatusRenderer)) === null || _44 === void 0 ? void 0 : _44.thumbnailOverlayTimeStatusRenderer) === null || _45 === void 0 ? void 0 : _45.text) === null || _46 === void 0 ? void 0 : _46.runs) === null || _47 === void 0 ? void 0 : _47[0]) === null || _48 === void 0 ? void 0 : _48.text) || ((_49 = da.lengthText) === null || _49 === void 0 ? void 0 : _49.simpleText) || "LIVE",
views: ((_52 = (_51 = (_50 = da.viewCount) === null || _50 === void 0 ? void 0 : _50.videoViewCountRenderer) === null || _51 === void 0 ? void 0 : _51.viewCount) === null || _52 === void 0 ? void 0 : _52.simpleText) || ((_53 = da.viewCountText) === null || _53 === void 0 ? void 0 : _53.simpleText) || ((_56 = (_55 = (_54 = da.viewCountText) === null || _54 === void 0 ? void 0 : _54.runs) === null || _55 === void 0 ? void 0 : _55[0]) === null || _56 === void 0 ? void 0 : _56.text) + ((_59 = (_58 = (_57 = da.viewCountText) === null || _57 === void 0 ? void 0 : _57.runs) === null || _58 === void 0 ? void 0 : _58[1]) === null || _59 === void 0 ? void 0 : _59.text) || ((_60 = da.videoDetails) === null || _60 === void 0 ? void 0 : _60.viewCount) || this.cc.Utils.deabreviateCnt(((_65 = (_64 = (_63 = (_62 = (_61 = da.metadataText) === null || _61 === void 0 ? void 0 : _61.simpleText) === null || _62 === void 0 ? void 0 : _62.split(" · ")) === null || _63 === void 0 ? void 0 : _63[0]) === null || _64 === void 0 ? void 0 : _64.split(" ")) === null || _65 === void 0 ? void 0 : _65[0]) || ((_70 = (_69 = (_68 = (_67 = (_66 = da.videoInfo) === null || _66 === void 0 ? void 0 : _66.runs) === null || _67 === void 0 ? void 0 : _67[0]) === null || _68 === void 0 ? void 0 : _68.text) === null || _69 === void 0 ? void 0 : _69.split(" ")) === null || _70 === void 0 ? void 0 : _70[0])) + " views" || "",
title: ((_71 = da.title) === null || _71 === void 0 ? void 0 : _71.simpleText) || ((_74 = (_73 = (_72 = da.title) === null || _72 === void 0 ? void 0 : _72.runs) === null || _73 === void 0 ? void 0 : _73[0]) === null || _74 === void 0 ? void 0 : _74.text) || ((_75 = da.videoDetails) === null || _75 === void 0 ? void 0 : _75.title) || "Fallback title",
id: ((_76 = da.videoDetails) === null || _76 === void 0 ? void 0 : _76.videoId) || da.videoId,
description: description,
upload: ((_77 = da.dateText) === null || _77 === void 0 ? void 0 : _77.simpleText) || ((_78 = da.publishedTimeText) === null || _78 === void 0 ? void 0 : _78.simpleText) || ((_81 = (_80 = (_79 = da.publishedTimeText) === null || _79 === void 0 ? void 0 : _79.runs) === null || _80 === void 0 ? void 0 : _80[0]) === null || _81 === void 0 ? void 0 : _81.text) || ((_83 = (_82 = da.microformat) === null || _82 === void 0 ? void 0 : _82.playerMicroformatRenderer) === null || _83 === void 0 ? void 0 : _83.publishDate) || ((_86 = (_85 = (_84 = da.metadataText) === null || _84 === void 0 ? void 0 : _84.simpleText) === null || _85 === void 0 ? void 0 : _85.split(" · ")) === null || _86 === void 0 ? void 0 : _86[1]) || "",
badges: da.badges || [],
thumbnail: (_89 = (_88 = (_87 = da.thumbnail) === null || _87 === void 0 ? void 0 : _87.thumbnails) === null || _88 === void 0 ? void 0 : _88[0]) === null || _89 === void 0 ? void 0 : _89.url,
tags: ((_90 = da.videoDetails) === null || _90 === void 0 ? void 0 : _90.keywords) || [],
isLive: (_91 = da.videoDetails) === null || _91 === void 0 ? void 0 : _91.isLive,
category: (window.location.pathname.split("/")[1] == "watch") ? (_93 = (_92 = ytInitialPlayerResponse === null || ytInitialPlayerResponse === void 0 ? void 0 : ytInitialPlayerResponse.microformat) === null || _92 === void 0 ? void 0 : _92.playerMicroformatRenderer) === null || _93 === void 0 ? void 0 : _93.category : ""
};
},
playlistData: (data) => {
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, _12, _13, _14, _15, _16, _17, _18, _19, _20, _21, _22, _23, _24, _25, _26, _27, _28, _29, _30, _31, _32, _33, _34, _35, _36, _37, _38, _39;
if (!data)
return {};
let views = (_d = (_c = (_b = data.viewCountText) === null || _b === void 0 ? void 0 : _b.simpleText) === null || _c === void 0 ? void 0 : _c.split(" ")) === null || _d === void 0 ? void 0 : _d[0];
return {
id: data.playlistId,
title: ((_g = (_f = (_e = data.title) === null || _e === void 0 ? void 0 : _e.runs) === null || _f === void 0 ? void 0 : _f[0]) === null || _g === void 0 ? void 0 : _g.text) || ((_h = data.title) === null || _h === void 0 ? void 0 : _h.simpleText) || data.title,
description: ((_j = data.descriptionText) === null || _j === void 0 ? void 0 : _j.simpleText) || ((_k = data.subtitle) === null || _k === void 0 ? void 0 : _k.simpleText) || "",
currentIndex: data.currentIndex,
videos: {
totalNumber: ((_l = data.videoCountShortText) === null || _l === void 0 ? void 0 : _l.simpleText) || data.totalVideos || data.videoCount,
text: ((_o = (_m = data.videoCountText) === null || _m === void 0 ? void 0 : _m.runs) === null || _o === void 0 ? void 0 : _o[1]) ? data.videoCountText.runs[0].text + data.videoCountText.runs[1].text : ((_r = (_q = (_p = data.videoCountText) === null || _p === void 0 ? void 0 : _p.runs) === null || _q === void 0 ? void 0 : _q[0]) === null || _r === void 0 ? void 0 : _r.text) || ((_u = (_t = (_s = data.numVideosText) === null || _s === void 0 ? void 0 : _s.runs) === null || _t === void 0 ? void 0 : _t[0]) === null || _u === void 0 ? void 0 : _u.text),
runs: (_v = data.videoCountText) === null || _v === void 0 ? void 0 : _v.runs,
videos: data.contents
},
views: this.cc.Utils.deabreviateCnt(parseInt(views === null || views === void 0 ? void 0 : views.replace(/,/g, "")) ? views : "0"),
owner: {
name: ((_y = (_x = (_w = data.ownerText) === null || _w === void 0 ? void 0 : _w.runs) === null || _x === void 0 ? void 0 : _x[0]) === null || _y === void 0 ? void 0 : _y.text) || ((_1 = (_0 = (_z = data.longBylineText) === null || _z === void 0 ? void 0 : _z.runs) === null || _0 === void 0 ? void 0 : _0[0]) === null || _1 === void 0 ? void 0 : _1.text),
url: ((_6 = (_5 = (_4 = (_3 = (_2 = data.ownerText) === null || _2 === void 0 ? void 0 : _2.runs) === null || _3 === void 0 ? void 0 : _3[0]) === null || _4 === void 0 ? void 0 : _4.navigationEndpoint) === null || _5 === void 0 ? void 0 : _5.browseEndpoint) === null || _6 === void 0 ? void 0 : _6.canonicalBaseUrl) || ((_11 = (_10 = (_9 = (_8 = (_7 = data.longBylineText) === null || _7 === void 0 ? void 0 : _7.runs) === null || _8 === void 0 ? void 0 : _8[0]) === null || _9 === void 0 ? void 0 : _9.navigationEndpoint) === null || _10 === void 0 ? void 0 : _10.browseEndpoint) === null || _11 === void 0 ? void 0 : _11.canonicalBaseUrl),
id: ((_16 = (_15 = (_14 = (_13 = (_12 = data.ownerText) === null || _12 === void 0 ? void 0 : _12.runs) === null || _13 === void 0 ? void 0 : _13[0]) === null || _14 === void 0 ? void 0 : _14.navigationEndpoint) === null || _15 === void 0 ? void 0 : _15.browseEndpoint) === null || _16 === void 0 ? void 0 : _16.browseId) || ((_21 = (_20 = (_19 = (_18 = (_17 = data.longBylineText) === null || _17 === void 0 ? void 0 : _17.runs) === null || _18 === void 0 ? void 0 : _18[0]) === null || _19 === void 0 ? void 0 : _19.navigationEndpoint) === null || _20 === void 0 ? void 0 : _20.browseEndpoint) === null || _21 === void 0 ? void 0 : _21.browseId)
},
updated: ((_22 = data.publishedTimeText) === null || _22 === void 0 ? void 0 : _22.simpleText) || "Updated a long time ago",
thumbnail: ((_25 = (_24 = (_23 = data.thumbnail) === null || _23 === void 0 ? void 0 : _23.thumbnails) === null || _24 === void 0 ? void 0 : _24[0]) === null || _25 === void 0 ? void 0 : _25.url) || ((_30 = (_29 = (_28 = (_27 = (_26 = data.thumbnailRenderer) === null || _26 === void 0 ? void 0 : _26.playlistVideoThumbnailRenderer) === null || _27 === void 0 ? void 0 : _27.thumbnail) === null || _28 === void 0 ? void 0 : _28.thumbnails) === null || _29 === void 0 ? void 0 : _29[0]) === null || _30 === void 0 ? void 0 : _30.url),
rawThumbnail: data.thumbnail || { thumbnails: (_32 = (_31 = data.thumbnailRenderer) === null || _31 === void 0 ? void 0 : _31.playlistVideoThumbnailRenderer) === null || _32 === void 0 ? void 0 : _32.thumbnail },
sidethumbs: data.sidebarThumbnails || data.thumbnails || [{ thumbnails: (((_33 = data.thumbnail) === null || _33 === void 0 ? void 0 : _33.thumbnails) || data.thumbnail) }],
url: ((_36 = (_35 = (_34 = data.navigationEndpoint) === null || _34 === void 0 ? void 0 : _34.commandMetadata) === null || _35 === void 0 ? void 0 : _35.webCommandMetadata) === null || _36 === void 0 ? void 0 : _36.url) || ((_39 = (_38 = (_37 = data.endpoint) === null || _37 === void 0 ? void 0 : _37.commandMetadata) === null || _38 === void 0 ? void 0 : _38.webCommandMetadata) === null || _39 === void 0 ? void 0 : _39.url)
};
},
feedData: (data) => {
var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
if (!data)
return {};
let _description = ((_b = data.contentText) === null || _b === void 0 ? void 0 : _b.runs) || [];
let description = "";
for (const snippet in _description) {
description += _description[snippet].text;
}
return {
owner: {
name: (_e = (_d = (_c = data.authorText) === null || _c === void 0 ? void 0 : _c.runs) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.text,
url: (_k = (_j = (_h = (_g = (_f = data.authorText) === null || _f === void 0 ? void 0 : _f.runs) === null || _g === void 0 ? void 0 : _g[0]) === null || _h === void 0 ? void 0 : _h.navigationEndpoint) === null || _j === void 0 ? void 0 : _j.browseEndpoint) === null || _k === void 0 ? void 0 : _k.canonicalBaseUrl,
id: "",
icon: (_m = (_l = data.authorThumbnail) === null || _l === void 0 ? void 0 : _l.thumbnails) === null || _m === void 0 ? void 0 : _m[0].url
},
id: data.postId,
upload: (_q = (_p = (_o = data.publishedTimeText) === null || _o === void 0 ? void 0 : _o.runs) === null || _p === void 0 ? void 0 : _p[0]) === null || _q === void 0 ? void 0 : _q.text,
description: description
};
},
homeFeedData: (data) => {
return {
author: data.title.simpleText,
avatar: data.thumbnail.thumbnails[0].url,
video: this.cc.Utils.Sort.videoData(data.content.expandedShelfContentsRenderer.items[0].videoRenderer)
};
},
commentData: (data) => {
var _b, _c, _d;
if (!data)
return {};
//var PRESENTABLE_COUNT = (RAW_COUNT + (liketoggled ? -1 : 0)) ? (RAW_COUNT + (liketoggled ? -1 : 0)).toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",") : '';
let _text = data.contentText.runs;
let text = "";
for (const snippet in _text) {
if (_text[snippet].navigationEndpoint) {
let href = (_d = (_c = (_b = _text[snippet].navigationEndpoint) === null || _b === void 0 ? void 0 : _b.commandMetadata) === null || _c === void 0 ? void 0 : _c.webCommandMetadata) === null || _d === void 0 ? void 0 : _d.url;
text += `<a href="${href}">${this.cc.Utils.escapeHtml(_text[snippet].text)}</a>`;
}
else {
text += this.cc.Utils.escapeHtml(_text[snippet].text);
}
}
text = text.replace(/(?:\r\n|\r|\n)/g, '<br/>');
return {
author: {
name: data.authorText.simpleText,
id: data.authorEndpoint.browseEndpoint.browseId,
url: data.authorEndpoint.browseEndpoint.canonicalBaseUrl
},
id: data.commentId,
text: text,
time: data.publishedTimeText.runs[0].text,
likes: data.voteCount ? data.voteCount.accessibility ? (data.voteCount.accessibility.accessibilityData ? parseInt(data.voteCount.accessibility.accessibilityData.label.replace(/[^0-9.]/g, '')) : '') : (data.voteCount.accessibility ? parseInt(data.voteCount.accessibility.label.replace(/[^0-9.]/g, '')) : '') : ''
};
}
};
this.cc = cc;
}
deabreviateCnt(count) {
if (count) {
var t, n, a = 0;
if (("M" == count.charAt(count.length - 1) && (a = 1),
"K" == count.charAt(count.length - 1) && (a = 2),
0 != a))
1 == a && ((t = "000,000"), (n = "M")),
2 == a && ((t = "000"), (n = "K")),
(count =
-1 != count.indexOf(".")
? count.split(".")[0] +
"," +
count.split(".")[1].split(n)[0].slice(0, 2) +
t.slice(count.split(".")[1].split(n)[0].length, t.length)
: count.substring(0, count.length - 1) + "," + t);
return count;
}
return null;
}
parseNumber(arg) {
try {
return arg.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
}
catch (_b) {
return String(arg);
}
}
currentPage() {
let _a = window.location.pathname.split("/")[1];
switch (true) {
case /channel|user|^c{1}$/.test(_a):
case /@/.test(_a):
_a = "channels";
break;
case window.location.pathname === "/" || window.location.pathname === "/feed/subscriptions":
_a = "home";
break;
case window.location.pathname === "/feed/explore":
_a = "feedExplore";
break;
case window.location.pathname === "/cosmic_cat":
_a = "settings";
}
return _a;
}
whatChannel() {
return `channels${this.cc.Storage.get("channel_mode").value}`;
}
convertXHRtoJSON(data) {
return data.then(da => {
try {
return JSON.parse(da.split("var ytInitialData = ")[1].split(";</script>")[0]);
}
catch (_b) {
return {};
}
});
}
getCookie(cname) {
var name = cname + "=";
var decodedCookie = decodeURIComponent(document.cookie);
var ca = decodedCookie.split(';');
for (let i = 0; i < ca.length; i++) {
var c = ca[i];
while (c.charAt(0) == ' ') {
c = c.substring(1);
}
if (c.indexOf(name) == 0) {
return c.substring(name.length, c.length);
}
}
return "";
}
setCookie(cname, cvalue, exdays) {
const d = new Date();
d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000));
let expires = "expires=" + d.toUTCString();
document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
}
addStyle(a) {
try {
var c;
try {
c = a.split("/www")[1].split("-").slice(0, -1).join("-");
}
catch (_b) { }
var b = document.createElement("link");
b.setAttribute("rel", "stylesheet");
b.setAttribute("href", a);
b.setAttribute("id", `www${c}-css`);
document.head.append(b);
}
catch (err) {
console.error(`[addStyle] Function must have an argument!:\n`, err);
}
}
escapeHtml(unsafe) {
try {
return unsafe
.replace(/&/g, "&")
.replace(/</g, "<")
.replace(/>/g, ">")
.replace(/"/g, """)
.replace(/'/g, "'");
}
catch (_b) {
return "";
}
}
waitForElm(e) {
return new Promise((t) => {
if (document.querySelector(e))
return t(document.querySelector(e));
const n = new MutationObserver((s) => {
document.querySelector(e) &&
(t(document.querySelector(e)), n.disconnect());
});
n.observe(document, {
childList: !0,
subtree: !0
});
});
}
waitForElm2() {
return new Promise(resolve => {
if (document.querySelector("body").innerHTML.match(/ytInitialData/)) {
return resolve(document.querySelector("body"));
}
const observer = new MutationObserver(mutations => {
if (document.querySelector("body").innerHTML.match(/ytInitialData/)) {
try {
let a = JSON.parse(document.body.innerHTML.substr(parseInt(document.body.innerHTML.search("var ytInitialData = ") + 20)).substr(0, parseInt(document.body.innerHTML.substr(parseInt(document.body.innerHTML.search("var ytInitialData = ") + 20)).search("</script>") - 1)));
(a.contents) && resolve(a) && observer.disconnect();
}
catch (_b) { }
}
});
observer.observe(document.body, {
childList: true,
subtree: true
});
});
}
listCategories(params) {
var href = "";
switch (true) {
case /trending/.test(params):
href = "/feed/trending";
break;
case /popular/.test(params):
href = "/channel/UCF0pVplsI8R5kcAqgtoRqoA";
break;
case /music/.test(params):
href = "/channel/UC-9-kyTW8ZkZNDHQJ6FgpwQ";
break;
case /live/.test(params):
href = "/channel/UC4R8DWoMoI7CAwX8_LjQHig";
break;
case /gadgets|gaming/.test(params):
href = "/gaming";
break;
case /news/.test(params):
href = "/channel/UCYfdidRxbB8Qhf0Nx7ioOYw";
break;
case /sports/.test(params):
href = "/channel/UCEgdi0XIXXZ-qJOFPf4JSKw";
break;
case /education/.test(params):
href = "/channel/UCtFRv9O2AHqOZjjynzrv-xg";
break;
case /howto/.test(params):
href = "/channel/UCrpQ4p1Ql_hG8rKXIKM1MOQ";
}
return {
name: localizeString("guide." + params),
href: href,
class: params
};
}
convertDescription(a) {
// https://github.com/Rehike/Rehike/commit/cdabdd0d951ef3df06905172777efbc1bb34c1d6
// Originally written by aubymori in PHP.
if (!a.commandRuns) {
return {
"runs": [
{
"text": a.content
}
]
};
}
var runs = [], start = 0;
for (var i = 0; i < a.commandRuns.length; i++) {
var run = a.commandRuns[i], beforeText = a.content.substr(start, run.startIndex - start);
if (beforeText) {
runs.push({
text: beforeText
});
}
var text = a.content.substring(run.startIndex, run.startIndex + run.length), endpoint = run.onTap.innertubeCommand;
runs.push({
text: text,
navigationEndpoint: endpoint
});
start = run.startIndex + run.length;
}
var lastText = a.content.substr(start);
if (lastText) {
runs.push({
text: lastText
});
}
runs.forEach(function (run) {
var _b;
if ((_b = run.navigationEndpoint) === null || _b === void 0 ? void 0 : _b.watchEndpoint) {
run.text = "https://www.youtube.com" + run.navigationEndpoint.commandMetadata.webCommandMetadata.url.substring(0, 37) + "...";
}
});
return {
runs: runs
};
}
}
class Pagination {
sortDataIntoArray(api) {
var _a;
let obj = [];
try {
obj = api === null || api === void 0 ? void 0 : api[0].appendContinuationItemsAction.continuationItems;
}
catch (_b) {
obj = (_a = api === null || api === void 0 ? void 0 : api[1]) === null || _a === void 0 ? void 0 : _a.reloadContinuationItemsCommand.continuationItems;
}
return obj;
}
nextNumberButton(continuation, number, type) {
number = Number(number);
let commCount = number;
let ana = () => {
document.querySelector(".yt-uix-button-toggled").classList.remove("yt-uix-button-toggled");
document.querySelector(`[data-page='${number}']`).classList.add("yt-uix-button-toggled");
let ded = document.querySelector("#next-btn");
ded.setAttribute("data-page", number + 1);
};
if (document.querySelector(`.yt-pp[data-page='${number}']`)) {
ana();
}
else {
if (number !== 0) {
let abc = document.querySelector(".yt-uix-pager");
let bcd = document.querySelector(".yt-uix-button-toggled");
let def = document.createElement("a");
let ded = document.querySelector("#next-btn");
def.setAttribute("class", "yt-uix-button yt-uix-sessionlink yt-uix-pager-button yt-uix-button-toggled yt-uix-button-default yt-pp");
def.setAttribute("data-page", number);
def.setAttribute("onclick", `document.cosmicCat.${type}.next(this.getAttribute('data-token'), this.getAttribute('data-page'))`);
def.setAttribute("aria-label", `Go to page ${number}`);
def.setAttribute("data-token", continuation);
def.innerHTML = `<span class="yt-uix-button-content">${number}</span>`;
ded.setAttribute("data-page", commCount + 1);
if (bcd) {
bcd.classList.remove("yt-uix-button-toggled");
}
abc.insertBefore(def, document.querySelector("#next-btn"));
}
}
}
}
let Comments$1 = class Comments {
constructor(cc) {
this.Form = {
init: function () {
if (document.querySelector(".comments-post").classList.contains("has-focus"))
return;
document.querySelector(".comments-post").classList.add("has-focus");
let fu = (e) => {
let l = e.target.textLength;
let L = 500;
let rg = L - l;
if (rg <= 0) {
document.querySelector(".comments-textarea").value = document.querySelector(".comments-textarea").value.substring(0, L);
}
document.querySelector(".comments-remaining-count").innerText = rg <= 0 ? 0 : rg;
};
document.querySelector(".comments-textarea").addEventListener("keyup", fu);
document.querySelector(".comments-textarea").addEventListener("input", fu);
},
uninit: function () {
if (!document.querySelector(".comments-post").classList.contains("has-focus"))
return;
let _dom = document.querySelector(".comments-post");
let _com = document.querySelector(".comments-textarea");
document.querySelector(".comments-remaining-count").innerText = "500";
_dom.classList.remove("has-focus");
_com.value = "";
_com.textContent = "";
}
};
this.cc = cc;
}
init(continuation) {
return __awaiter(this, void 0, void 0, function* () {
if (!continuation)
return this.cc.toggleElm("#comments-view");
let api = yield this.cc.Ajax.post("/youtubei/v1/next", `continuation: "${continuation}"`, "WEB", "2.20230331.00.00");
if (!api)
return this.abort();
try {
var session = "";
try {
session = api.onResponseReceivedEndpoints[0].reloadContinuationItemsCommand.continuationItems[0].commentsHeaderRenderer.createRenderer.commentSimpleboxRenderer.submitButton.buttonRenderer.serviceEndpoint.createCommentEndpoint.createCommentParams;
}
catch (err) {
try {
session = api.onResponseReceivedEndpoints[0].reloadContinuationItemsCommand.continuationItems[0].commentsHeaderRenderer.createRenderer.commentSimpleboxRenderer.submitButton.buttonRenderer.serviceEndpoint.channelCreationServiceEndpoint.zeroStepChannelCreationParams.zeroStepCreateCommentParams.createCommentParams;
}
catch (err) {
throw new Error(err);
}
}
if (api.responseContext.mainAppWebResponseContext.loggedOut == false && document.querySelector("#session").getAttribute("data-yes") !== "yes") {
document.querySelector("#session").setAttribute("data-yes", "yes");
document.querySelector("#session").value = session;
}
}
catch (err) {
console.error("[Comments] Couldn't check if user is logged in or out:", err);
}
const sortMenuTokens = this.sortMenuTokens(api);
let sortedCommentsArray = this.cc.Pagination.sortDataIntoArray(api.onResponseReceivedEndpoints);
if (!sortedCommentsArray)
return this.abort();
sortedCommentsArray = sortedCommentsArray.splice(0, 2);
const comments = this.sortComments(sortedCommentsArray, "top");
document.querySelector(".comment-list.top").innerHTML = comments.result;
this.cc.toggleElm(".comment-list.top");
yield this.cc.Comments.load(sortMenuTokens.newest);
});
}
load(continuation) {
return __awaiter(this, void 0, void 0, function* () {
if (!continuation)
return this.cc.toggleElm("#next-btn");
let api = yield this.cc.Ajax.post("/youtubei/v1/next", `continuation: "${continuation}"`, "WEB", "2.20230331.00.00");
if (!api)
return this.abort();
let sortedCommentsArray = this.cc.Pagination.sortDataIntoArray(api.onResponseReceivedEndpoints);
const comments = this.sortComments(sortedCommentsArray, "all");
this.cc.Pagination.nextNumberButton(continuation, 1, "Comments");
document.querySelector(".comment-list.all").innerHTML = comments.result;
this.cc.toggleElm(".comment-list.all");
this.cc.toggleElm("#comments-loading");
});
}
abort() {
this.cc.toggleElm("#comments-loading");
}
sortComments(params, am) {
let result = { result: "", con: "" };
for (let i = 0; i < params.length; i++) {
if (params[i].commentThreadRenderer) {
if (am == "top" || params[i].commentThreadRenderer.renderingPriority !== "RENDERING_PRIORITY_PINNED_COMMENT") {
result.result += this.cc.Template.Comments.Comment(this.cc.Utils.Sort.commentData(params[i].commentThreadRenderer.comment.commentRenderer));
}
}
if (params[i].continuationItemRenderer && am == "all") {
const aaaa = document.querySelector("#next-btn");
if (aaaa.classList.contains("hid")) {
this.cc.toggleElm("#next-btn");
}
aaaa.setAttribute("data-token", params[i].continuationItemRenderer.continuationEndpoint.continuationCommand.token);
result.con += `${params[i].continuationItemRenderer.continuationEndpoint.continuationCommand.token}`;
}
}
return result;
}
sortMenuTokens(obj) {
return {
top: obj.onResponseReceivedEndpoints[0].reloadContinuationItemsCommand.continuationItems[0].commentsHeaderRenderer.sortMenu.sortFilterSubMenuRenderer.subMenuItems[0].serviceEndpoint.continuationCommand.token,
newest: obj.onResponseReceivedEndpoints[0].reloadContinuationItemsCommand.continuationItems[0].commentsHeaderRenderer.sortMenu.sortFilterSubMenuRenderer.subMenuItems[1].serviceEndpoint.continuationCommand.token
};
}
next(continuation, number) {
return __awaiter(this, void 0, void 0, function* () {
if (!continuation)
return this.cc.toggleElm("#next-btn");
this.cc.toggleElm("#comments-loading");
let api = yield this.cc.Ajax.post("/youtubei/v1/next", `continuation: "${continuation}"`, "WEB", "2.20230331.00.00");
if (!api)
return this.abort();
let sortedCommentsArray = this.cc.Pagination.sortDataIntoArray(api.onResponseReceivedEndpoints);
const comments = this.sortComments(sortedCommentsArray, "all");
this.cc.Pagination.nextNumberButton(continuation, number, "Comments");
document.querySelector(".comment-list.all").innerHTML = comments.result;
this.cc.toggleElm("#comments-loading");
});
}
};
let Search$1 = class Search {
constructor(cc) {
this.cc = cc;
}
abort() {
this.cc.toggleElm("#comments-loading");
}
sortResults(params, am) {
let result = { result: "", con: "" };
for (let i = 0; i < params[0].itemSectionRenderer.contents.length; i++) {
if (params[0].itemSectionRenderer.contents[i].videoRenderer) {
let c = this.cc.Utils.Sort.videoData(params[0].itemSectionRenderer.contents[i].videoRenderer);
result.result += this.cc.Template.Search.videoRender(c);
}
}
const aaaa = document.querySelector("#next-btn");
if (aaaa.classList.contains("hid")) {
this.cc.toggleElm("#next-btn");
}
aaaa.setAttribute("data-token", params[1].continuationItemRenderer.continuationEndpoint.continuationCommand.token);
result.con += `${params[1].continuationItemRenderer.continuationEndpoint.continuationCommand.token}`;
return result;
}
next(continuation, number) {
return __awaiter(this, void 0, void 0, function* () {
if (!continuation)
return this.cc.toggleElm("#next-btn");
//this.cc.toggleElm("#loading");
let api = yield this.cc.Ajax.post("/youtubei/v1/search", `continuation: "${continuation}"`, "WEB", "2.20230331.00.00");
if (!api)
return this.abort();
let sortedResultsArray = this.cc.Pagination.sortDataIntoArray(api.onResponseReceivedCommands);
const comments = this.sortResults(sortedResultsArray);
this.cc.Pagination.nextNumberButton(continuation, number, "Search");
document.querySelector("#search-results").innerHTML = comments.result;
});
}
};
var Channels = {
Channels3: {
Pagination: {
load: function () {
return __awaiter(this, void 0, void 0, function* () {
document.getElementsByClassName("channels-browse-gutter-padding")[2].innerHTML = document.cosmicCat.Template.Channel.Channels3.primaryPane.browseVideos.Navigation();
try {
document.querySelector("#next-btn").setAttribute("data-token", document.cosmicCat.Utils.browseTabs.content(document.cosmicCat.Utils.browseTabs.find(ytInitialData, "videos")).find(a => a.continuationItemRenderer).continuationItemRenderer.continuationEndpoint.continuationCommand.token);
}
catch (e) {
console.error("[Channels] Pagination request failed:\n", e);
}
});
},
next: function (continuation, number) {
return __awaiter(this, void 0, void 0, function* () {
if (!continuation)
return document.cosmicCat.toggleElm("#next-btn");
let api = yield document.cosmicCat.Ajax.post("/youtubei/v1/browse", `continuation: "${continuation}"`, "WEB", "2.20230331.00.00");
if (!api)
return this.abort();
let sortedResultsArray = document.cosmicCat.Pagination.sortDataIntoArray(api.onResponseReceivedActions);
const comments = this.sortResults(sortedResultsArray);
document.cosmicCat.Pagination.nextNumberButton(continuation, number, "Channels.Channels3.Pagination");
document.querySelector(".channels-browse-content-grid").innerHTML = comments.result;
});
},
sortResults: function (params, am) {
var _a, _b;
let result = { result: "", con: "" };
for (let i = 0; i < params.length; i++) {
if ((_b = (_a = params[i].richItemRenderer) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.videoRenderer) {
let c = document.cosmicCat.Utils.Sort.videoData(params[i].richItemRenderer.content.videoRenderer);
result.result += document.cosmicCat.Template.Channel.Channels3.primaryPane.browseVideos.listItem.videos(c);
}
}
const aaaa = document.querySelector("#next-btn");
if (aaaa.classList.contains("hid")) {
document.cosmicCat.toggleElm("#next-btn");
}
aaaa.setAttribute("data-token", params.find(a => a.continuationItemRenderer).continuationItemRenderer.continuationEndpoint.continuationCommand.token);
result.con += `${params.find(a => a.continuationItemRenderer).continuationItemRenderer.continuationEndpoint.continuationCommand.token}`;
return result;
}
}
},
Channels2: {},
getChannelID: (a) => {
return a.split("UC")[1];
},
playnav: {
selectTab: (a, b) => __awaiter(void 0, void 0, void 0, function* () {
window.location.pathname.split("/")[2];
document.querySelector("#playnav-play-loading").style.display = "block";
document.querySelector(".navbar-tab-selected").classList.remove("navbar-tab-selected");
b.classList.add("navbar-tab-selected");
window.location.hash = "#p/" + (a == "playlists" ? "p" : "u");
let data = yield document.cosmicCat.Ajax.Fetch(`https://www.youtube.com${window.location.pathname.split("/").slice(0, -1).join("/")}/${a}`, document.cosmicCat.Channels._Data[a.charAt(0).toUpperCase() + a.slice(1)]);
document.cosmicCat.pageRenderer.set("#playnav-play-content", document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.PlayPanel.Holder.Main());
for (let i = 0; i < data.length; i++) {
document.cosmicCat.pageRenderer.add(".scrollbox-page", document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.PlayPanel.Holder[a](data[i]));
}
document.querySelector("#playnav-play-loading").style.display = "none";
}),
like: (a, b) => {
alert("Hello world.");
},
toggleFullVideoDescription: (a) => {
var b = document.querySelector("#playnav-curvideo-description-more-holder"), c = document.querySelector("#playnav-curvideo-description-less"), d = document.querySelector("#playnav-curvideo-description-container");
(a === true) &&
((b.style.display = "none"),
(c.style.display = "inline"),
(d.style.height = "auto")) ||
((b.style.display = "inline"),
(c.style.display = "none"),
(d.style.height = "56px"));
}
},
isChannelsPage: () => {
return (window.location.pathname.split("/")[1].match(/channel|user/i) || (window.location.pathname.substr(1, 2) === "c/") || document.cosmicCat.Channels.isUsertag()) ? true : false;
},
checkIfSubscribed: () => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
try {
if (document.cosmicCat.Channels.isChannelsPage()) {
return ((_c = (_b = (_a = ytInitialData.header.c4TabbedHeaderRenderer) === null || _a === void 0 ? void 0 : _a.subscribeButton) === null || _b === void 0 ? void 0 : _b.subscribeButtonRenderer) === null || _c === void 0 ? void 0 : _c.subscribed) || ((_j = (_h = (_g = (_f = (_e = (_d = ytInitialData.header.carouselHeaderRenderer) === null || _d === void 0 ? void 0 : _d.contents) === null || _e === void 0 ? void 0 : _e.find(a => a.topicChannelDetailsRenderer)) === null || _f === void 0 ? void 0 : _f.topicChannelDetailsRenderer) === null || _g === void 0 ? void 0 : _g.subscribeButton) === null || _h === void 0 ? void 0 : _h.subscribeButtonRenderer) === null || _j === void 0 ? void 0 : _j.subscribed) || false;
}
if (window.location.pathname.split("/")[1].match(/watch/i)) {
return (_r = (_q = (_p = (_o = (_m = (_l = (_k = ytInitialData.contents.twoColumnWatchNextResults.results) === null || _k === void 0 ? void 0 : _k.results) === null || _l === void 0 ? void 0 : _l.contents) === null || _m === void 0 ? void 0 : _m.find(a => a.videoSecondaryInfoRenderer)) === null || _o === void 0 ? void 0 : _o.videoSecondaryInfoRenderer) === null || _p === void 0 ? void 0 : _p.subscribeButton) === null || _q === void 0 ? void 0 : _q.subscribeButtonRenderer) === null || _r === void 0 ? void 0 : _r.subscribed;
}
}
catch (err) {
console.error("[Channels] Something went wrong with executing \"checkIfSubscribed()\":\n", err);
return false;
}
},
toggleSubscribe: () => {
try {
if (document.cosmicCat.Channels.isChannelsPage()) {
try {
console.debug(ytInitialData.header.c4TabbedHeaderRenderer.subscribeButton);
ytInitialData.header.c4TabbedHeaderRenderer.subscribeButton.subscribeButtonRenderer.subscribed = ytInitialData.header.c4TabbedHeaderRenderer.subscribeButton.subscribeButtonRenderer.subscribed ? false : true;
}
catch (_a) {
try {
ytInitialData.header.carouselHeaderRenderer.contents.find(a => a.topicChannelDetailsRenderer).topicChannelDetailsRenderer.subscribeButton.subscribeButtonRenderer.subscribed = ytInitialData.header.carouselHeaderRenderer.contents.find(a => a.topicChannelDetailsRenderer).topicChannelDetailsRenderer.subscribeButton.subscribeButtonRenderer.subscribed ? false : true;
}
catch (err) {
console.error("[toggleSubscribe]:", err);
}
}
}
if (window.location.pathname.split("/")[1].match(/watch/i)) {
console.debug(ytInitialData.contents.twoColumnWatchNextResults.results.results.contents.find(a => a.videoSecondaryInfoRenderer).videoSecondaryInfoRenderer.subscribeButton);
ytInitialData.contents.twoColumnWatchNextResults.results.results.contents.find(a => a.videoSecondaryInfoRenderer).videoSecondaryInfoRenderer.subscribeButton.subscribeButtonRenderer.subscribed = ytInitialData.contents.twoColumnWatchNextResults.results.results.contents.find(a => a.videoSecondaryInfoRenderer).videoSecondaryInfoRenderer.subscribeButton.subscribeButtonRenderer.subscribed ? false : true;
}
}
catch (err) {
console.error("[Channels] Something went wrong with executing \"toggleSubscribe()\":\n", err);
}
},
isUsertag: () => {
return (window.location.pathname.substring(1, 2) === "@");
},
getCurrentChannelTab: () => {
let mode = document.cosmicCat.Storage.get("channel_mode").value;
switch (mode) {
case "1":
case "3":
mode = window.location.search.substr(1, 5) === "query" ? "search" : window.location.pathname.split("/")[document.cosmicCat.Channels.isUsertag() ? 2 : 3];
break;
case "2":
mode = window.location.hash.length > 1 && window.location.hash.slice(1).split("/")[1] == "p" ? "playlists" : "videos" ;
}
return mode;
},
getNaviHash: () => { return (document.cosmicCat.Channels.getCurrentChannelTab() == "playlists" ? "p" : "u"); },
isCurrentChannelTab: (params) => {
return (document.cosmicCat.Channels.getCurrentChannelTab() == params);
},
customTags: (data) => {
if (!data)
return [];
let tags = [];
let TAGS = data.matchAll(/\[\+\w\+="(\d+|.+)"]/g);
data = data.replace(/\[\+\w\+="(\d+|.+)"]/g, "");
for (const tag of TAGS) {
if (tag[0].split(/\+/g)[1] == "a" && tag[0].match(/"\d+"/g) && tag[0].split(/"/g)[1] < 101) {
tags.push({ name: "Age", value: tag[0].split(/"/g)[1] });
}
if (tag[0].split(/\+/g)[1] == "o" && tag[0].match(/"\w+/g)) {
tags.push({ name: "Occupation", value: tag[0].split(/"/g)[1] });
}
}
return tags;
},
isOwner: (data) => {
var _a, _b;
try {
return ((_b = (_a = ytInitialData === null || ytInitialData === void 0 ? void 0 : ytInitialData.header) === null || _a === void 0 ? void 0 : _a.c4TabbedHeaderRenderer) === null || _b === void 0 ? void 0 : _b.editChannelButtons) ? true : false;
}
catch (err) {
console.error("[Channels] Something went wrong with executing \"isOwner()\":\n", err);
return false;
}
},
load2Modules: (data) => {
document.cosmicCat.pageRenderer.add("#main-channel-left", document.cosmicCat.Template.Channel.Channels2.moduleContainer.profile(data));
document.cosmicCat.pageRenderer.add("#main-channel-left", document.cosmicCat.Template.Channel.Channels2.moduleContainer.userInfo(data));
},
Local: {
Header: () => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
try {
return document.cosmicCat.Utils.Sort.channelData(((_a = ytInitialData.header) === null || _a === void 0 ? void 0 : _a.c4TabbedHeaderRenderer) || ((_e = (_d = (_c = (_b = ytInitialData.header) === null || _b === void 0 ? void 0 : _b.carouselHeaderRenderer) === null || _c === void 0 ? void 0 : _c.contents) === null || _d === void 0 ? void 0 : _d[0]) === null || _e === void 0 ? void 0 : _e.topicChannelDetailsRenderer) || ((_j = (_h = (_g = (_f = ytInitialData.header) === null || _f === void 0 ? void 0 : _f.carouselHeaderRenderer) === null || _g === void 0 ? void 0 : _g.contents) === null || _h === void 0 ? void 0 : _h[1]) === null || _j === void 0 ? void 0 : _j.topicChannelDetailsRenderer) || ((_k = ytInitialData.header) === null || _k === void 0 ? void 0 : _k.interactiveTabbedHeaderRenderer));
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel data:\n", err);
}
},
SearchResults: () => {
if (window.location.search.substr(1, 5) !== "query")
return false;
return document.cosmicCat.Channels._Data.SearchResults(ytInitialData);
},
Videos: () => {
if (document.cosmicCat.Channels.getCurrentChannelTab() !== "videos")
return false;
return document.cosmicCat.Channels._Data.Videos(ytInitialData);
},
Playlists: () => {
if (document.cosmicCat.Channels.getCurrentChannelTab() !== "playlists")
return false;
return document.cosmicCat.Channels._Data.Playlists(ytInitialData);
},
Community: () => {
if (document.cosmicCat.Channels.getCurrentChannelTab() !== "community")
return [];
return document.cosmicCat.Channels._Data.Community(ytInitialData);
}
},
_Data: {
SearchResults: (data) => {
let result = [];
try {
let tab = data.contents.twoColumnBrowseResultsRenderer.tabs.find(a => a.expandableTabRenderer).expandableTabRenderer.content;
let contents = document.cosmicCat.Utils.browseTabs.content(tab);
console.log(contents);
if (!contents)
throw Error();
for (let i = 0; i < contents.length; i++) {
if (!contents[i].continuationItemRenderer) {
result[i] = document.cosmicCat.Utils.Sort.videoData(contents[i].itemSectionRenderer.contents[0].videoRenderer);
}
}
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel search results:\n", err);
}
return result;
},
Videos: (data) => {
let result = [];
try {
let tab = document.cosmicCat.Utils.browseTabs.find(data, "videos");
let contents = document.cosmicCat.Utils.browseTabs.content(tab);
if (!contents)
throw Error();
for (let i = 0; i < contents.length; i++) {
if (!contents[i].continuationItemRenderer) {
result[i] = document.cosmicCat.Utils.Sort.videoData(contents[i].richItemRenderer.content.videoRenderer);
}
}
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel videos:\n", err);
}
return result;
},
Playlists: (data) => {
let result = [];
try {
let tab = document.cosmicCat.Utils.browseTabs.find(data, "playlists");
let content = document.cosmicCat.Utils.browseTabs.content(tab), contents = [];
for (const i in content) {
try {
contents.push(content[i].shelfRenderer.content.horizontalListRenderer.items);
}
catch (_a) {
try {
contents.push(content[i].gridRenderer.items);
}
catch (_b) {
try {
contents.push(content[i].itemSectionRenderer.contents[0].shelfRenderer.content.horizontalListRenderer.items);
}
catch (_c) {
try {
contents.push(content[i].itemSectionRenderer.contents[0].gridRenderer.items);
}
catch (_d) {
try {
contents.push(content[i].itemSectionRenderer.contents[0].shelfRenderer.content.expandedShelfContentsRenderer.items);
}
catch (_e) {
console.log(content[i]);
throw Error("No playlists were found.");
}
}
}
}
}
}
;
if (!contents)
throw Error();
try {
contents = [...contents[0], ...contents[1]];
}
catch (_f) {
contents = [...contents[0]];
}
for (let i = 0; i < contents.length; i++) {
if (!contents[i].continuationItemRenderer) {
result[i] = document.cosmicCat.Utils.Sort.playlistData(contents[i].gridPlaylistRenderer || contents[i].playlistRenderer);
}
}
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel playlists:\n", err);
}
return result;
},
Community: (data) => {
let result = [];
try {
let tab = document.cosmicCat.Utils.browseTabs.find(data, "community");
let contents = document.cosmicCat.Utils.browseTabs.content(tab)[0].itemSectionRenderer.contents;
if (!contents)
throw Error();
for (let i = 0; i < contents.length; i++) {
if (!contents[i].continuationItemRenderer) {
result[i] = document.cosmicCat.Utils.Sort.feedData(contents[i].backstagePostThreadRenderer.post.backstagePostRenderer);
}
}
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel feeds:\n", err);
}
return result;
},
Info: (data) => {
var _a, _b, _c, _d, _e, _f, _g;
let result = {};
try {
let tab = document.cosmicCat.Utils.browseTabs.find(data, "about");
let contents = document.cosmicCat.Utils.browseTabs.content(tab)[0].itemSectionRenderer.contents[0].channelAboutFullMetadataRenderer;
if (!contents)
throw Error();
result = document.cosmicCat.Utils.Sort.channelData(contents);
try {
result.subs = document.cosmicCat.Utils.deabreviateCnt(((_d = (_c = (_b = (_a = data.header.c4TabbedHeaderRenderer) === null || _a === void 0 ? void 0 : _a.subscriberCountText) === null || _b === void 0 ? void 0 : _b.simpleText) === null || _c === void 0 ? void 0 : _c.split(" ")) === null || _d === void 0 ? void 0 : _d[0]) || ((_g = (_f = (_e = data.subs) === null || _e === void 0 ? void 0 : _e.simpleText) === null || _f === void 0 ? void 0 : _f.split(" ")) === null || _g === void 0 ? void 0 : _g[0]) || "0");
}
catch (err) {
console.error("[Channels] Something went wrong with sorting subscriber count:\n", err);
}
}
catch (err) {
console.error("[Channels] Something went wrong with sorting channel info:\n", err);
}
return result;
}
}
};
var Playlists = {
Local: {
Header: () => {
let result = [];
try {
return document.cosmicCat.Utils.Sort.playlistData(ytInitialData.header.playlistHeaderRenderer);
}
catch (err) {
console.error("[Playlists] Something went wrong with sorting playlist data:\n", err);
}
return result;
},
Videos: () => {
let result = [];
try {
let contents = ytInitialData.contents.twoColumnBrowseResultsRenderer.tabs[0].tabRenderer.content.sectionListRenderer.contents[0].itemSectionRenderer.contents[0].playlistVideoListRenderer.contents;
for (let i = 0; i < contents.length; i++) {
if (!contents[i].continuationItemRenderer) {
result[i] = document.cosmicCat.Utils.Sort.videoData(contents[i].playlistVideoRenderer);
}
}
}
catch (err) {
console.error("[Playlists] Something went wrong with sorting video data:\n", err);
}
return result;
}
}
};
var Home = {
Feed: {
load: (params) => {
var _a, _b, _c, _d, _e, _f;
document.querySelector(".selected").classList.remove("selected");
params.classList.add("selected");
document.querySelector(".feed-header-info").innerText = params.dataset.feedDisplay;
(_b = (_a = document.querySelector("#feed-error:not(.hid)")) === null || _a === void 0 ? void 0 : _a.classList) === null || _b === void 0 ? void 0 : _b.add("hid");
(_d = (_c = document.querySelector(".feed-header:not(.hid)")) === null || _c === void 0 ? void 0 : _c.classList) === null || _d === void 0 ? void 0 : _d.add("hid");
(_f = (_e = document.querySelector("#feed-main-youtube:not(.hid)")) === null || _e === void 0 ? void 0 : _e.classList) === null || _f === void 0 ? void 0 : _f.add("hid");
document.querySelector(".context-data-container").innerHTML = "";
document.cosmicCat.toggleElm("#feed-loading-template");
document.cosmicCat.Ajax.Fetch(params.dataset.feedUrl, document.cosmicCat.Home.Feed.newFeed);
},
newFeed: (ytData, a) => __awaiter(void 0, void 0, void 0, function* () {
console.debug(ytData);
try {
let tabs = ytData.contents.twoColumnBrowseResultsRenderer.tabs[0].tabRenderer.content;
let contents = tabs.richGridRenderer || tabs.sectionListRenderer;
try {
for (let i = 0; i < contents.contents.length; i++) {
if (!contents.contents[i].continuationItemRenderer) {
var thisItem = "";
if (contents.contents[i].richItemRenderer && contents.contents[i].richItemRenderer.content.videoRenderer) {
thisItem = document.cosmicCat.Template.Homepage.Feed.Main(document.cosmicCat.Utils.Sort.videoData(contents.contents[i].richItemRenderer.content.videoRenderer));
}
if (contents.contents[i].itemSectionRenderer && contents.contents[i].itemSectionRenderer.contents[0].shelfRenderer.content.expandedShelfContentsRenderer.items[0].videoRenderer) {
thisItem = document.cosmicCat.Template.Homepage.Feed.Main(document.cosmicCat.Utils.Sort.videoData(contents.contents[i].itemSectionRenderer.contents[0].shelfRenderer.content.expandedShelfContentsRenderer.items[0].videoRenderer));
}
document.cosmicCat.pageRenderer.add(".context-data-container", thisItem);
}
}
document.cosmicCat.Home.Feed.complete();
}
catch (err) {
console.error("[Home Feed] Failed to parse feed data:\n", err);
document.cosmicCat.Home.Feed.error();
}
}
catch (err) {
console.error("[Home Feed] Failed to parse YouTube data:\n", err);
document.cosmicCat.Home.Feed.error();
}
}),
complete: () => {
document.cosmicCat.toggleElm("#feed-loading-template");
document.cosmicCat.toggleElm(".feed-header");
document.cosmicCat.toggleElm("#feed-main-youtube");
},
error: () => {
var _a, _b;
(_b = (_a = document.querySelector("#feed-main-youtube:not(.hid)")) === null || _a === void 0 ? void 0 : _a.classList) === null || _b === void 0 ? void 0 : _b.add("hid");
document.cosmicCat.toggleElm("#feed-loading-template");
document.cosmicCat.toggleElm("#feed-error");
}
}
};
class Subscriptions {
constructor(cc) {
this.cc = cc;
}
getChannelInfo() {
return __awaiter(this, void 0, void 0, function* () {
try {
let t = yield fetch("https://www.youtube.com/feed/channels");
return this.cc.Subscriptions.handleData(t.text(), 1);
}
catch (err) {
console.error("[Subscriptions] Something went wrong with fetching subscriptions data:\n", err);
return [];
}
});
}
getFeedInfo() {
return __awaiter(this, void 0, void 0, function* () {
try {
let t = yield fetch("https://www.youtube.com/feed/subscriptions?flow=2");
return this.cc.Subscriptions.handleData(t.text());
}
catch (err) {
console.error("[Subscriptions] Something went wrong with fetching subscriptions data:\n", err);
return [];
}
});
}
handleData(a, b) {
return a.then(n => {
let p = JSON.parse(n.split("var ytInitialData = ")[1].split(";</script>")[0]).contents.twoColumnBrowseResultsRenderer.tabs[0].tabRenderer.content;
return p ? p.sectionListRenderer.contents[0].itemSectionRenderer.contents[0].shelfRenderer.content.expandedShelfContentsRenderer.items : [];
});
}
}
class Animations {
start(a, b) {
// motivation dropped before i got to write more
// also this is probably a bad way to do animations
b.classList.add(a);
}
}
var watch = {
Suggestions: {
load: () => __awaiter(void 0, void 0, void 0, function* () {
let toggleElms = () => {
document.cosmicCat.toggleElm("#watch-more-related-button");
document.cosmicCat.toggleElm("#watch-more-related");
};
toggleElms();
document.cosmicCat.Ajax.post("/youtubei/v1/next", `continuation: "${document.cosmicCat.data.tokenSlot1}"`, "WEB", "2.20230331.00.00").then(api => {
var _a, _b, _c;
let collection = ((_c = (_b = (_a = api === null || api === void 0 ? void 0 : api.onResponseReceivedEndpoints) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.appendContinuationItemsAction) === null || _c === void 0 ? void 0 : _c.continuationItems) || [];
for (let i = 0; i < collection.length; i++) {
if (collection[i].compactVideoRenderer) {
let videoData = document.cosmicCat.Utils.Sort.videoData(collection[i].compactVideoRenderer);
document.cosmicCat.pageRenderer.add("#watch-related", document.cosmicCat.Template.Watch.Content.mainCon.sideBar.suggestedVideo(videoData));
}
if (collection[i].continuationItemRenderer) {
document.cosmicCat.data.tokenSlot1 = collection[i].continuationItemRenderer.continuationEndpoint.continuationCommand.token;
}
}
toggleElms();
});
})
},
actions: {
like: (a, b) => {
if (!document.cosmicCat.Utils.getCookie("SAPISID")) {
return document.cosmicCat.watch.actions;
}
if (document.cosmicCat.watch.isVideoLiked()) {
a.classList.remove("liked");
document.cosmicCat.Ajax.post("/youtubei/v1/like/removelike", `target:{videoId: "${ytInitialPlayerResponse.videoDetails.videoId}"}`, "WEB", "2.20230331.00.00");
}
else {
if (document.cosmicCat.watch.isVideoDisliked()) {
document.querySelector("#watch-unlike").classList.remove("unliked");
}
a.classList.add("liked");
document.cosmicCat.Ajax.post("/youtubei/v1/like/like", `target:{videoId: "${ytInitialPlayerResponse.videoDetails.videoId}"}`, "WEB", "2.20230331.00.00");
}
try {
ytInitialData.contents.twoColumnWatchNextResults.results.results.contents[0].videoPrimaryInfoRenderer.videoActions.menuRenderer.topLevelButtons[0].segmentedLikeDislikeButtonRenderer.likeButton.toggleButtonRenderer.isToggled = ytInitialData.contents.twoColumnWatchNextResults.results.results.contents[0].videoPrimaryInfoRenderer.videoActions.menuRenderer.topLevelButtons[0].segmentedLikeDislikeButtonRenderer.likeButton.toggleButtonRenderer.isToggled ? false : true;
}
catch (err) {
console.error("[Watch] Failed to un/like video:", err);
}
},
unlike: (a, b) => {
if (!document.cosmicCat.Utils.getCookie("SAPISID")) {
return document.cosmicCat.watch.actions;
}
if (document.cosmicCat.watch.isVideoDisliked()) {
a.classList.remove("unliked");
document.cosmicCat.Ajax.post("/youtubei/v1/like/removelike", `target:{videoId: "${ytInitialPlayerResponse.videoDetails.videoId}"}`, "WEB", "2.20230331.00.00");
}
else {
if (document.cosmicCat.watch.isVideoLiked()) {
document.querySelector("#watch-like").classList.remove("liked");
}
a.classList.add("unliked");
document.cosmicCat.Ajax.post("/youtubei/v1/like/dislike", `target:{videoId: "${ytInitialPlayerResponse.videoDetails.videoId}"}`, "WEB", "2.20230331.00.00");
}
try {
ytInitialData.contents.twoColumnWatchNextResults.results.results.contents[0].videoPrimaryInfoRenderer.videoActions.menuRenderer.topLevelButtons[0].segmentedLikeDislikeButtonRenderer.dislikeButton.toggleButtonRenderer.isToggled = ytInitialData.contents.twoColumnWatchNextResults.results.results.contents[0].videoPrimaryInfoRenderer.videoActions.menuRenderer.topLevelButtons[0].segmentedLikeDislikeButtonRenderer.dislikeButton.toggleButtonRenderer.isToggled ? false : true;
}
catch (err) {
console.error("[Watch] Failed to un/like video:", err);
}
},
share: (a, b) => {
document.querySelector("#watch-actions-area-container").classList.remove("hid");
document.querySelector("#watch-actions-share").classList.remove("hid");
// unfinished
// document.cosmicCat.Animations.start("transitioning", document.querySelector("#watch-actions-area-container"));
console.log(a);
}
},
watch5: {
handleLoadMoreRelated: () => document.cosmicCat.watch.Suggestions.load()
},
isOwner: () => {
var _a;
try {
return ((_a = ytInitialPlayerResponse === null || ytInitialPlayerResponse === void 0 ? void 0 : ytInitialPlayerResponse.videoDetails) === null || _a === void 0 ? void 0 : _a.isOwnerViewing) || false;
}
catch (_b) {
return false;
}
},
isVideoLiked: () => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
return (_p = (_o = (_m = (_l = (_k = (_j = (_h = (_g = (_f = (_e = (_d = (_c = (_b = (_a = ytInitialData.contents) === null || _a === void 0 ? void 0 : _a.twoColumnWatchNextResults) === null || _b === void 0 ? void 0 : _b.results) === null || _c === void 0 ? void 0 : _c.results) === null || _d === void 0 ? void 0 : _d.contents) === null || _e === void 0 ? void 0 : _e[0]) === null || _f === void 0 ? void 0 : _f.videoPrimaryInfoRenderer) === null || _g === void 0 ? void 0 : _g.videoActions) === null || _h === void 0 ? void 0 : _h.menuRenderer) === null || _j === void 0 ? void 0 : _j.topLevelButtons) === null || _k === void 0 ? void 0 : _k[0]) === null || _l === void 0 ? void 0 : _l.segmentedLikeDislikeButtonRenderer) === null || _m === void 0 ? void 0 : _m.likeButton) === null || _o === void 0 ? void 0 : _o.toggleButtonRenderer) === null || _p === void 0 ? void 0 : _p.isToggled;
},
isVideoDisliked: () => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
return (_p = (_o = (_m = (_l = (_k = (_j = (_h = (_g = (_f = (_e = (_d = (_c = (_b = (_a = ytInitialData.contents) === null || _a === void 0 ? void 0 : _a.twoColumnWatchNextResults) === null || _b === void 0 ? void 0 : _b.results) === null || _c === void 0 ? void 0 : _c.results) === null || _d === void 0 ? void 0 : _d.contents) === null || _e === void 0 ? void 0 : _e[0]) === null || _f === void 0 ? void 0 : _f.videoPrimaryInfoRenderer) === null || _g === void 0 ? void 0 : _g.videoActions) === null || _h === void 0 ? void 0 : _h.menuRenderer) === null || _j === void 0 ? void 0 : _j.topLevelButtons) === null || _k === void 0 ? void 0 : _k[1]) === null || _l === void 0 ? void 0 : _l.segmentedLikeDislikeButtonRenderer) === null || _m === void 0 ? void 0 : _m.dislikeButton) === null || _o === void 0 ? void 0 : _o.toggleButtonRenderer) === null || _p === void 0 ? void 0 : _p.isToggled;
}
};
class Browse {
constructor(cc) {
this.cc = cc;
}
_Data(data) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
let result = [];
try {
let tab = data.contents.twoColumnBrowseResultsRenderer.tabs[0];
let contents = tab.tabRenderer.content;
try {
contents = contents.richGridRenderer.contents;
}
catch (_o) {
contents = contents.sectionListRenderer.contents;
}
let c = [];
for (let i = 0; i < contents.length; i++) {
let b_a = ((_b = (_a = contents[i].itemSectionRenderer) === null || _a === void 0 ? void 0 : _a.contents) === null || _b === void 0 ? void 0 : _b[0]) || contents[i].richItemRenderer || {};
let b_b = ((_e = (_d = (_c = b_a.shelfRenderer) === null || _c === void 0 ? void 0 : _c.content) === null || _d === void 0 ? void 0 : _d.gridRenderer) === null || _e === void 0 ? void 0 : _e.items) || ((_h = (_g = (_f = b_a.shelfRenderer) === null || _f === void 0 ? void 0 : _f.content) === null || _g === void 0 ? void 0 : _g.expandedShelfContentsRenderer) === null || _h === void 0 ? void 0 : _h.items) || ((_l = (_k = (_j = b_a.shelfRenderer) === null || _j === void 0 ? void 0 : _j.content) === null || _k === void 0 ? void 0 : _k.horizontalListRenderer) === null || _l === void 0 ? void 0 : _l.items) || ((_m = b_a.horizontalCardListRenderer) === null || _m === void 0 ? void 0 : _m.cards);
if (b_b) {
for (let i_ = 0; i_ < b_b.length; i_++) {
if (b_b[i_].gridVideoRenderer || b_b[i_].videoRenderer || b_b[i_].videoCardRenderer) {
c.push(b_b[i_].gridVideoRenderer || b_b[i_].videoRenderer || b_b[i_].videoCardRenderer);
}
}
}
if (b_a.content && b_a.content.videoRenderer) {
c.push(b_a.content.videoRenderer);
}
}
for (let i = 0; i < c.length; i++) {
if (i < 4) {
result[i] = this.cc.Utils.Sort.videoData(c[i]);
}
}
}
catch (err) {
console.error(err);
}
return result;
}
}
class Storage {
init() {
const STORAGE = localStorage.getItem("cosmic-cat-config");
console.debug("Storage.init", STORAGE);
if (!STORAGE)
return this.build();
console.info("Storage.init", "storage has init.");
}
build() {
const obj = {
"storageVer": "0",
"lang": "en",
"dark": "0",
"i18n": {},
"i18n.setup": "0",
"iframe": "1",
"channel_mode": "3",
"greeting_feed": "youtube"
};
localStorage.setItem("cosmic-cat-config", JSON.stringify(obj));
}
get(a) {
const STORAGE = JSON.parse(localStorage.getItem("cosmic-cat-config"));
return {
name: a,
exists: !!STORAGE[a],
value: STORAGE[a]
};
}
add(a, b) {
let obj = JSON.parse(localStorage.getItem("cosmic-cat-config"));
obj[a] = b;
console.debug("Storage.add", obj[a]);
localStorage.setItem("cosmic-cat-config", JSON.stringify(obj));
}
remove(a) {
const STORAGE = JSON.parse(localStorage.getItem("cosmic-cat-config"));
delete STORAGE[a];
localStorage.setItem("cosmic-cat-config", JSON.stringify(STORAGE));
}
}
class PageRenderer {
constructor(cc) {
this.cc = cc;
}
error() {
try {
this.cc.Alert(2, "Oops! Something went wrong with rendering the page. <a href=''>Click here</a> to refresh the page.");
}
catch (_a) { }
}
set(selector, html) {
this.original = selector;
try {
selector = document.querySelector(selector);
selector.innerHTML = html;
}
catch (err) {
//this.cc.pageRenderer.error();
console.error(`[pageRenderer]: "${selector}" does not exist.\n`, err);
}
}
replace(selector1, selector2) {
try {
document.querySelector(selector1).outerHTML = selector2;
}
catch (err) {
console.error(`[pageRenderer]: "${selector1}" does not exist.\n`, err);
}
}
add(selector, html) {
this.original = selector;
try {
selector = document.querySelector(selector);
selector.innerHTML += html;
}
catch (err) {
//this.cc.pageRenderer.error();
console.error(`[pageRenderer]: "${this.original}" does not exist\n`, err);
}
}
}
class Actions {
constructor(cc) {
this.cc = cc;
}
handleButton(b, a) {
var _a, _b, _c;
return (((_c = (_b = (_a = b.dataset.buttonAction) === null || _a === void 0 ? void 0 : _a.slice(7)) === null || _b === void 0 ? void 0 : _b.split('.')) === null || _c === void 0 ? void 0 : _c.reduce((o, i) => o[i] || "", this.cc)) || this.cc.null)(b, b.dataset);
}
handleSubscribeButton(a, b) {
return __awaiter(this, void 0, void 0, function* () {
let classn = "";
let d = a.dataset.subscriptionValue;
let c = (a.classList.contains("subscribed") || a.classList.contains("yt-subscription-button-green")) ? "unsubscribe" : "subscribe";
switch (this.cc.Utils.currentPage()) {
case "channels2":
classn = ".subscription-container";
d = a.parentElement.dataset.subscriptionValue;
break;
case "watch":
case "channels":
classn = ".yt-subscription-button-hovercard";
break;
case "playlist":
classn = ".enable-fancy-subscribe-button";
}
console.debug("[handleSubscribeButton]:", d, c);
try {
this.cc.Ajax.post(`/youtubei/v1/subscription/${c}`, `channelIds: ["${d}"]`, "WEB", "2.20230331.00.00").then((a) => {
console.debug("[handleSubscribeButton]:", a);
this.cc.Channels.toggleSubscribe();
this.cc.pageRenderer.replace(classn, this.cc.Template.Buttons.Subscribe(d));
});
}
catch (err) {
console.error(`[Subscribe] Something went wrong with subscribing to ${d}:\n`, err);
}
});
}
handleSettingsButton(a, b) {
return this.cc.Settings.toggleOption(a, a.dataset);
}
handleSettingsTab(a, b) {
return this.cc.Settings.toggleTab(a, a.dataset);
}
handleGuideItem(a, b) {
this.cc.Home.Feed.load(a.children[0]);
}
handleExpander() {
this.cc.toggleElm("#masthead-expanded");
}
}
class Picker {
constructor(cc) {
this.cc = cc;
}
load(a, b) {
this.cc.Ajax.post(`/youtubei/v1/account/account_menu`, "", "WEB", "2.20230331.00.00").then((a) => {
var c = a.actions[0].openPopupAction.popup.multiPageMenuRenderer.sections[2].multiPageMenuSectionRenderer.items.find(a => { var _a, _b; return (_b = (_a = a === null || a === void 0 ? void 0 : a.compactLinkRenderer) === null || _a === void 0 ? void 0 : _a.icon) === null || _b === void 0 ? void 0 : _b.iconType; });
console.log(c);
});
console.log(a, b);
}
}
var www = {
404: () => {
document.cosmicCat.pageRenderer.set("title", "404 Not Found");
document.cosmicCat.pageRenderer.set("body", document.cosmicCat.Template.errorNotFound());
},
home: () => {
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Homepage.Main());
let guidebuilder = "";
let subsbuilder = "";
if (document.cosmicCat.Storage.get("accountInfo").exists) {
guidebuilder = document.cosmicCat.Template.Homepage.Guide.Builder.loggedIn();
subsbuilder = document.cosmicCat.Template.Homepage.Guide.Personal();
}
else {
guidebuilder = document.cosmicCat.Template.Homepage.Guide.Builder.loggedOut();
}
document.cosmicCat.pageRenderer.set("#guide-builder-promo", guidebuilder);
document.cosmicCat.pageRenderer.set(".guide", subsbuilder);
document.cosmicCat.pageRenderer.add(".guide", document.cosmicCat.Template.Homepage.Guide.Categories.Main());
try {
for (let i = 0; i < document.cosmicCat.data.homeCategories.length; i++) {
let caties = document.cosmicCat.Utils.listCategories(document.cosmicCat.data.homeCategories[i]);
document.cosmicCat.pageRenderer.add(".cockie", document.cosmicCat.Template.Homepage.Guide.Categories.Channel(caties));
}
}
catch (err) {
console.error("[Home] Could not parse categories:\n", err);
}
try {
if (window.location.pathname == "/feed/subscriptions") {
document.cosmicCat.Home.Feed.load(document.querySelector("[data-feed-name='subscriptions']"));
}
else {
if (document.cosmicCat.Storage.get("greeting_feed").value == "youtube") {
$(document).ready(function () {
document.cosmicCat.Home.Feed.newFeed(ytInitialData);
document.cosmicCat.toggleElm("#feed-loading-template");
document.cosmicCat.toggleElm("#feed-main-youtube");
});
}
else {
document.cosmicCat.Home.Feed.load(document.querySelector(`[data-feed-name='${document.cosmicCat.Storage.get("greeting_feed").value}']`));
}
}
}
catch (err) {
console.error("[Home] Could not load feed data:\n", err);
}
try {
if (document.cosmicCat.Storage.get("accountInfo").exists) {
document.cosmicCat.Subscriptions.getChannelInfo().then(subsarr => {
for (let i = 0; i < subsarr.length; i++) {
document.cosmicCat.pageRenderer.add("#guide-subscriptions", document.cosmicCat.Template.Homepage.Guide.Channel(subsarr[i]));
}
});
}
else {
}
}
catch (err) {
console.error("[Home] Could not load subscriptions:\n", err);
}
},
watch: () => {
$(document).ready(function () {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
let data = {
primary: document.cosmicCat.Utils.Sort.videoData((_c = (_b = (_a = ytInitialData.contents.twoColumnWatchNextResults.results) === null || _a === void 0 ? void 0 : _a.results) === null || _b === void 0 ? void 0 : _b.contents[0]) === null || _c === void 0 ? void 0 : _c.videoPrimaryInfoRenderer),
secondary: document.cosmicCat.Utils.Sort.videoData((_f = (_e = (_d = ytInitialData.contents.twoColumnWatchNextResults.results) === null || _d === void 0 ? void 0 : _d.results) === null || _e === void 0 ? void 0 : _e.contents[1]) === null || _f === void 0 ? void 0 : _f.videoSecondaryInfoRenderer),
alternative: document.cosmicCat.Utils.Sort.videoData(ytInitialPlayerResponse)
};
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Watch.Content.Main(data));
document.querySelector("#page").classList.add("watch");
fetch("https://returnyoutubedislikeapi.com/Votes?videoId=" + data.alternative.id)
.then((response) => response.json())
.then((result) => {
var likes = result.likes;
var dislikes = result.dislikes;
var rating = likes + dislikes > 0 ? (likes / (likes + dislikes)) * 100 : 50;
document.querySelector(".video-extras-sparkbar-likes").style.width = rating + "%";
document.querySelector(".likes").innerText = likes.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
document.querySelector(".dislikes").innerText = dislikes.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
}).catch((err) => {
console.error("[ReturnYouTubeDislikes] Something went wrong with fetching api:\n", err);
});
try {
for (let i = 0; i < data.alternative.tags.length; i++) {
document.cosmicCat.pageRenderer.add("#eow-tags", document.cosmicCat.Template.Watch.Content.tag(data, i));
}
}
catch (err) {
console.error("[Watch] Failed to load video tags.\n", err);
}
try {
if (ytInitialData.contents.twoColumnWatchNextResults.playlist.playlist) {
let data = document.cosmicCat.Utils.Sort.playlistData(ytInitialData.contents.twoColumnWatchNextResults.playlist.playlist);
document.cosmicCat.pageRenderer.add("#page", document.cosmicCat.Template.Watch.Content.playlistBar.Main(data));
for (let i = 0; i < data.videos.videos.length; i++) {
document.cosmicCat.pageRenderer.add("ol.video-list", document.cosmicCat.Template.Watch.Content.playlistBar.barTray.trayContent.video(document.cosmicCat.Utils.Sort.videoData(data.videos.videos[i].playlistPanelVideoRenderer), data));
}
}
}
catch (err) {
console.debug("[Playlists] No playlist loaded.");
}
try {
if (!0 == data.alternative.isLive) {
var iframe = document.createElement("iframe");
iframe.src = "https://www.youtube.com/live_chat?v=" + data.alternative.id;
iframe.height = "500";
document.querySelector("#watch-sidebar").insertAdjacentElement("afterbegin", iframe);
}
}
catch (_p) { }
try {
const obj_sug = ((_l = (_k = (_j = (_h = (_g = ytInitialData.contents.twoColumnWatchNextResults.secondaryResults) === null || _g === void 0 ? void 0 : _g.secondaryResults) === null || _h === void 0 ? void 0 : _h.results) === null || _j === void 0 ? void 0 : _j[1]) === null || _k === void 0 ? void 0 : _k.itemSectionRenderer) === null || _l === void 0 ? void 0 : _l.contents) || ((_o = (_m = ytInitialData.contents.twoColumnWatchNextResults.secondaryResults) === null || _m === void 0 ? void 0 : _m.secondaryResults) === null || _o === void 0 ? void 0 : _o.results);
for (let i = 0; i < obj_sug.length; i++) {
if (obj_sug[i].compactVideoRenderer) {
let videoData = document.cosmicCat.Utils.Sort.videoData(obj_sug[i].compactVideoRenderer);
document.cosmicCat.pageRenderer.add("#watch-related", document.cosmicCat.Template.Watch.Content.mainCon.sideBar.suggestedVideo(videoData));
}
if (obj_sug[i].continuationItemRenderer) {
document.cosmicCat.data.tokenSlot1 = obj_sug[i].continuationItemRenderer.continuationEndpoint.continuationCommand.token;
document.cosmicCat.pageRenderer.add(".watch-sidebar-foot p.content", document.cosmicCat.Template.Buttons.watchMoreRelated());
}
}
}
catch (err) {
console.error("[Watch] Failed to load suggestions.\n", err);
}
try {
if (ytInitialData.contents.twoColumnWatchNextResults.results.results.contents.filter(b => b.itemSectionRenderer)[1]) {
document.cosmicCat.toggleElm("#comments-view");
let con = ytInitialData.contents.twoColumnWatchNextResults.results.results.contents.filter(b => b.itemSectionRenderer)[1].itemSectionRenderer.contents[0].continuationItemRenderer.continuationEndpoint.continuationCommand.token;
document.cosmicCat.Comments.init(con);
}
}
catch (err) {
console.error("[Comments] Failed to load the comments section.\n\nUseful errors, if any:", err);
}
if (!data.alternative.id) {
document.querySelector("#player").remove();
}
document.head.querySelector("title").innerText = `${data.primary.title} - YouTube`;
document.cosmicCat.vorapisPlayer(data.alternative.id);
document.querySelector("body").addEventListener("submit", (e) => __awaiter(this, void 0, void 0, function* () {
e.preventDefault();
let comm = document.querySelector(".comments-textarea").value;
if (comm.length < 1)
return;
document.cosmicCat.Ajax.post("/youtubei/v1/comment/create_comment", `createCommentParams: "${document.querySelector("input#session").value}", commentText: "${comm}"`, "WEB", "2.20230331.00.00").then((api) => __awaiter(this, void 0, void 0, function* () {
if (api.actionResult.status == "STATUS_SUCCEEDED") {
let re = api.actions[0].runAttestationCommand.ids;
let comments = document.querySelector("ul.comment-list.all");
let comment = document.createElement("li");
comment.setAttribute("class", "comment yt-tile-default");
comment.setAttribute("data-author-id", re[2].externalChannelId);
comment.setAttribute("data-id", re[0].commentId);
comment.setAttribute("data-score", "-1");
let json = { authorText: { simpleText: document.cosmicCat.Storage.get("accountInfo").value.name }, commentId: re[0].commentId, contentText: { runs: [{ text: comm }] }, publishedTimeText: { runs: [{ text: "Just now" }] }, authorEndpoint: { browseEndpoint: { canonicalBaseUrl: document.cosmicCat.Storage.get("accountInfo").value.link } } };
let newc = document.cosmicCat.Template.Comments.Comment(document.cosmicCat.Utils.Sort.commentData(json));
comment.innerHTML = newc;
comments.insertBefore(comment, comments.children[0]);
document.cosmicCat.Comments.Form.uninit();
yield document.cosmicCat.Ajax.post("/youtubei/v1/att/get", `engagementType: "ENGAGEMENT_TYPE_COMMENT_POST", ids: ${JSON.stringify(re)}`, "WEB", "2.20230331.00.00");
}
}));
return false;
}));
});
},
shorts: () => {
window.location.href = "https://www.youtube.com/watch?v=" + window.location.pathname.split("/")[2];
},
channels: () => {
(!/^featured|videos|playlists|community$/g.test(window.location.pathname.split("/").splice(document.cosmicCat.Channels.isUsertag() ? 2 : 3).join("/"))) && window.location.replace(window.location.pathname.split("/").slice(0, document.cosmicCat.Channels.isUsertag() ? 2 : 3).join("/") + "/featured");
$(document).ready(function () {
var _a, _b;
return __awaiter(this, void 0, void 0, function* () {
let revision = document.cosmicCat.Storage.get("channel_mode").value;
document.cosmicCat.Channels.getNaviHash();
(revision == "3") && document.querySelector("#page").setAttribute("class", "branded-page channel");
(revision == "2" && /playlists/.test(window.location.pathname.split("/").splice(2).join("/"))) && window.location.replace(window.location.pathname.split("/").slice(0, 2).join("/") + "/videos");
let data = {
info: yield document.cosmicCat.Ajax.Fetch(`https://www.youtube.com${window.location.pathname.split("/").slice(0, -1).join("/")}/about`, document.cosmicCat.Channels._Data.Info),
header: document.cosmicCat.Channels.Local.Header(),
content: document.cosmicCat.Channels.Local.SearchResults() || document.cosmicCat.Channels.Local.Videos() || document.cosmicCat.Channels.Local.Playlists() || document.cosmicCat.Channels.Local.Community()
};
document.head.querySelector("title").innerText = `${data.header.name}'s ${localizeString("global.channel")} - YouTube`;
revision = "Channels" + document.cosmicCat.Storage.get("channel_mode").value;
document.cosmicCat.Channels.getCurrentChannelTab();
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Channel[revision].Main(data));
const list = {
"Channels3": {
"contentList": ".channels-browse-content-grid",
"contentListAddr": "primaryPane.browseVideos.listItem"
},
"Channels2": {
"contentList": ".scrollbox-page",
"contentListAddr": "playlistNavigator.Content.PlayPanel.Holder"
},
"Channels1": {
"contentList": "#profileVideos [style=\"border-bottom:none;\"]",
"contentListAddr": "mainCon.userVideos"
}
};
try {
var player = ytInitialData.contents.twoColumnBrowseResultsRenderer.tabs[0].tabRenderer.content.sectionListRenderer.contents.find(player => player.itemSectionRenderer.contents[0].channelVideoPlayerRenderer || player.itemSectionRenderer.contents[0].channelFeaturedContentRenderer);
player = player.itemSectionRenderer.contents[0].channelVideoPlayerRenderer || player.itemSectionRenderer.contents[0].channelFeaturedContentRenderer.items[0].videoRenderer;
}
catch (_c) { }
if (revision == "Channels2") {
document.cosmicCat.pageRenderer.add("body", document.cosmicCat.Template.Channel.Channels2.Stylesheet()),
document.cosmicCat.Channels.load2Modules(data.info);
try {
document.cosmicCat.pageRenderer.add("#playnav-video-panel-inner", document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.LeftPanel.Info(document.cosmicCat.Utils.Sort.videoData(player), data.header));
}
catch (_d) { }
document.cosmicCat.Channels.playnav.selectTab("videos", document.querySelector("#playnav-navbar-tab-uploads"));
}
if (revision == "Channels3") {
try {
document.cosmicCat.pageRenderer.add(".tab-content-body", document.cosmicCat.Template.Channel.Channels3.primaryPane[document.cosmicCat.Channels.isCurrentChannelTab("featured") ? "featured" : "browseVideos"].Main(data));
}
catch (_e) { }
try {
document.cosmicCat.pageRenderer.add(".tab-content-body", document.cosmicCat.Template.Channel.Channels3.secondaryPane.Main(data));
}
catch (_f) { }
try {
for (let i = 0; i < ((_b = (_a = data.info) === null || _a === void 0 ? void 0 : _a.links) === null || _b === void 0 ? void 0 : _b.length); i++) {
document.cosmicCat.pageRenderer.add(".profile-socials", document.cosmicCat.Template.Channel.Channels3.secondaryPane.firstSection.socialLink(data.info.links[i].channelExternalLinkViewModel));
}
}
catch (err) {
console.error("[Channels] Failed to parse social links:\n", err);
}
if (document.cosmicCat.Channels.isCurrentChannelTab("featured")) {
try {
document.cosmicCat.pageRenderer.add(".primary-pane", document.cosmicCat.Template.Channel.Channels3.primaryPane.featured.featuredVideo(document.cosmicCat.Utils.Sort.videoData(player), data.header));
}
catch (_g) { }
}
}
// data.content = (data.content.length == 0) && await document.cosmicCat.Ajax.Fetch(`https://www.youtube.com${window.location.pathname.split("/").slice(0, -1).join("/")}/${tab}`, document.cosmicCat.Channels._Data[tab.charAt(0).toUpperCase() + tab.slice(1)]) || data.content;
try {
//
//document.cosmicCat.Ajax.post("/youtubei/v1/creator/get_creator_channels", `"channelIds":["${data.header.id}"],"mask":{"channelId":true,"title":true,"metric":{"all":true}}`, "62", "1.20211213.02.00")
(revision == "Channels1") && (document.querySelector("[name^=\"channel-box-item-count\"]").innerText = data.content.length);
}
catch (err) { }
try {
for (let i = 0; i < data.content.length; i++) {
document.cosmicCat.pageRenderer.add(list[revision].contentList, list[revision].contentListAddr.split('.').reduce((o, i) => o[i] || "", document.cosmicCat.Template.Channel[revision])[document.cosmicCat.Channels.getCurrentChannelTab()](data.content[i], data.content.length));
}
}
catch (err) {
console.error("[Channels] Failed to parse local content data:\n", err);
}
(revision == "Channels2") && (document.querySelector("#playnav-play-loading").style.display = "none");
console.log(data.content.length);
(revision == "Channels3" && data.content.length > 29) && (document.cosmicCat.Channels.Channels3.Pagination.load());
document.cosmicCat.vorapisPlayer(document.cosmicCat.Utils.Sort.videoData(player).id);
});
});
},
playlist: () => {
$(document).ready(function () {
var _a, _b;
return __awaiter(this, void 0, void 0, function* () {
let data = {
header: document.cosmicCat.Playlists.Local.Header(),
content: document.cosmicCat.Playlists.Local.Videos()
};
if (data.header.owner.id) {
data.creatorInfo = yield document.cosmicCat.Ajax.Fetch(`https://www.youtube.com/channel/${(_b = (_a = data === null || data === void 0 ? void 0 : data.header) === null || _a === void 0 ? void 0 : _a.owner) === null || _b === void 0 ? void 0 : _b.id}/about`, document.cosmicCat.Channels._Data.Info);
}
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Playlist.Main(data));
try {
for (let i = 0; i < data.content.length; i++) {
document.cosmicCat.pageRenderer.add("ol", document.cosmicCat.Template.Playlist.primaryPane.listItem.video(data.content[i], data.header.id, i + 1));
}
}
catch (err) {
console.error("[Playlists] Failed to parse playlist content:\n", err);
}
});
});
},
results: () => {
$(document).ready(function () {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
var searchpar = document.cosmicCat.Utils.escapeHtml((new URL(document.location)).searchParams.get("search_query"));
document.querySelector("#page").classList.add("search-base");
var results = (_e = (_d = (_c = (_b = (_a = ytInitialData === null || ytInitialData === void 0 ? void 0 : ytInitialData.contents) === null || _a === void 0 ? void 0 : _a.twoColumnSearchResultsRenderer) === null || _b === void 0 ? void 0 : _b.primaryContents) === null || _c === void 0 ? void 0 : _c.sectionListRenderer) === null || _d === void 0 ? void 0 : _d.contents.find(a => { var _a, _b, _c; return (_c = (_b = (_a = a === null || a === void 0 ? void 0 : a.itemSectionRenderer) === null || _a === void 0 ? void 0 : _a.contents) === null || _b === void 0 ? void 0 : _b[1]) === null || _c === void 0 ? void 0 : _c.videoRenderer; }).itemSectionRenderer) === null || _e === void 0 ? void 0 : _e.contents;
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Search.Main(searchpar));
try {
for (let i = 0; i < results.length; i++) {
if (results[i].videoRenderer) {
let videoData = document.cosmicCat.Utils.Sort.videoData(results[i].videoRenderer);
document.cosmicCat.pageRenderer.add("#search-results", document.cosmicCat.Template.Search.videoRender(videoData));
}
if (results[i].channelRenderer) {
let channelData = document.cosmicCat.Utils.Sort.channelData(results[i].channelRenderer);
document.cosmicCat.pageRenderer.add("#search-results", document.cosmicCat.Template.Search.channelRender(channelData));
}
if (results[i].playlistRenderer) {
let playlistData = document.cosmicCat.Utils.Sort.playlistData(results[i].playlistRenderer);
document.cosmicCat.pageRenderer.add("#search-results", document.cosmicCat.Template.Search.playlistRender(playlistData));
}
}
}
catch (err) {
// I love inconsistent data <3
console.error("[Search] Failed to parse search results.\n", err, "\nData appears to be inconsistent. fuck u YT.");
document.cosmicCat.Alert(2, "Cosmic Cat Error: Failed to parse search results. Check console for more details.");
}
var a = ytInitialData.header.searchHeaderRenderer.searchFilterButton.buttonRenderer.command.openPopupAction.popup.searchFilterOptionsDialogRenderer.groups;
var temF = (data, b) => document.cosmicCat.Template.Search.dropdownFilter.Con(data, b, searchpar);
for (const b in a) {
var temC = ``;
for (const c in a[b].searchFilterGroupRenderer.filters) {
temC += temF((_l = (_k = (_j = (_h = (_g = (_f = a[b]) === null || _f === void 0 ? void 0 : _f.searchFilterGroupRenderer) === null || _g === void 0 ? void 0 : _g.filters[c]) === null || _h === void 0 ? void 0 : _h.searchFilterRenderer) === null || _j === void 0 ? void 0 : _j.navigationEndpoint) === null || _k === void 0 ? void 0 : _k.searchEndpoint) === null || _l === void 0 ? void 0 : _l.params, a[b].searchFilterGroupRenderer.filters[c].searchFilterRenderer.label.simpleText);
}
document.cosmicCat.pageRenderer.add("#filter-dropdown", document.cosmicCat.Template.Search.dropdownFilter.Main(a, b, temC));
}
});
},
feedExplore: () => {
document.body.setAttribute("class", "ytg-old-clearfix guide-feed-v2");
document.head.querySelector("title").innerText = "Videos - YouTube";
$(document).ready(function () {
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Browse.Main());
//document.cosmicCat.Alert(1, "This page is under reconstruction!");
document.querySelector(".load-more-pagination").remove();
});
},
settings: () => {
document.querySelector("body").setAttribute("cosmic_cat_settings", "");
document.querySelector("body").classList.add("guide-feed-v2");
document.querySelector("title").innerText = "Cosmic Cat Settings";
const guidecss = document.createElement("link");
guidecss.setAttribute("id", "www-guide");
guidecss.setAttribute("rel", "stylesheet");
guidecss.setAttribute("href", "//s.ytimg.com/yts/cssbin/www-guide-vfljovH6N.css");
document.querySelector("head").appendChild(guidecss);
addHandler("input", "cosmic-cat-settings", document.cosmicCat.Actions.handleSettingsButton);
document.cosmicCat.pageRenderer.set("#content-container", document.cosmicCat.Template.Settings.Main() + document.cosmicCat.Template.Settings.Stylesheet());
$(document).ready(function () {
$("#channelMode").val(document.cosmicCat.Storage.get("channel_mode").value);
$("#mainFeed").val(document.cosmicCat.Storage.get("greeting_feed").value);
});
},
};
var errorNotFound = () => {
return `<div id="error-page">
<div id="error-page-content">
<img id="error-page-illustration" src="//s.ytimg.com/yt/img/image-404-vfl1vwmey.png" alt="">
<p>We're sorry, the page you requested cannot be found. Try searching for something else.</p>
<div id="masthead">
<a id="logo-container" href="https://www.youtube.com/" title="YouTube home">
<img id="logo" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="YouTube home">
</a>
<form id="masthead-search" class="search-form consolidated-form" action="https//www.youtube.com/results" onsubmit="if (_gel('masthead-search-term').value == '') return false;">
<button class="search-btn-compontent search-button yt-uix-button yt-uix-button-default" onclick="if (_gel('masthead-search-term').value == '') return false; _gel('masthead-search').submit(); return false;;return true;" type="submit" id="search-btn" dir="ltr" tabindex="2" role="button"><span class="yt-uix-button-content">Search </span></button>
<div id="masthead-search-terms" class="masthead-search-terms-border" dir="ltr">
<label><input id="masthead-search-term" autocomplete="off" class="search-term" name="search_query" value="" type="text" tabindex="1" onkeyup="goog.i18n.bidi.setDirAttribute(event,this)" title="Search"></label>
</div>
</form>
</div>
</div>
<span id="error-page-vertical-align"></span>
</div>`;
};
var Alerts = (param, msg) => {
let type = "";
switch (param) {
case 0:
type = "info";
break;
case 1:
type = "warn";
break;
case 2:
type = "error";
break;
}
return `<div class="yt-alert yt-alert-default yt-alert-${type}" style="display: block;">
<div class="yt-alert-icon">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</div>
<div class="yt-alert-buttons">
<button type="button" class="close yt-uix-close yt-uix-button yt-uix-button-close" onclick="document.cosmicCat.toggleElm('.yt-alert-default');return false;" data-close-parent-class="yt-alert" role="button">
<span class="yt-uix-button-content">Close</span>
</button>
</div>
<div class="yt-alert-content" role="alert"><span class="yt-alert-vertical-trick"></span>
<div class="yt-alert-message">${msg}</div>
</div></div>`;
};
var BrowseMain = () => {
return `<div id="baseDiv" class="video-info browse-base browse-videos">
<div id="masthead-subnav" class="yt-nav yt-nav-dark">
<ul>${document.cosmicCat.Template.Browse.Subnav.Main()}</ul>
</div>
<div class="browse-container ytg-wide ytg-box no-stage browse-bg-gradient">
<div class="ytg-fl browse-content">
<div id="browse-side-column" class="ytg-2col ytg-last">
<ol class="navigation-menu">
<li class="menu-item">
<a class="selected" href="https://www.youtube.com/feed/explore">All Categories</a>
</li>
<li class="menu-item">
<a class="" href="">Recommended for You</a>
</li>
</ol>
</div>
<div id="browse-main-column" class="ytg-4col">
<div class="load-more-pagination">
<div id="feed-loading-template">
<div class="feed-message">
<p class="loading-spinner">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
${localizeString("global.loading.main")}
</p>
</div>
</div>
<div class="load-more-content"></div>
</div>
</div>
</div>
</div>
<div class="clear"></div>
</div>`;
};
var BrowseSubnav = {
Main: () => {
let items = "";
let a = ytInitialData.contents.twoColumnBrowseResultsRenderer.tabs;
for (let i = 0; i < a.length; i++) {
items += document.cosmicCat.Template.Browse.Subnav.navItem(a[i].tabRenderer.title);
}
return `<div id="masthead-subnav" class="yt-nav yt-nav-dark">
<ul>${items}</ul>
</div>`;
},
navItem: (data) => {
return `<li>
<span class="yt-nav-item">${data}</span>
</li>`;
}
};
var BrowseContent = {
Category: (data, videos) => {
return `<div class="browse-collection">
<div class="ytg-box collection-header with-icon">
<a class="heading ytg-box" href="${data.href}">
<img class="header-icon ${data.class}" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
<div class="header-container">
<h2>${data.name} »</h2>
</div>
</a>
<a class="yt-playall-link yt-playall-link-default yt-uix-sessionlink" href="${data.href}" data-sessionlink="">
<img class="small-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">Play all
</a>
</div>
<div class="browse-item-row ytg-box">${videos}</div>
</div>`;
},
Video: (data) => {
var _a, _b;
return `<div class="browse-item yt-tile-default">
<a href="https://www.youtube.com/watch?v=${data.id}" class="ux-thumb-wrap yt-uix-sessionlink yt-uix-contextlink contains-addto" data-sessionlink="">
<span class="video-thumb ux-thumb yt-thumb-default-194">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="//i1.ytimg.com/vi/${data.id}/mqdefault.jpg" alt="Thumbnail" data-thumb="//i1.ytimg.com/vi/${data.id}/mqdefault.jpg" data-group-key="thumb-group-0" width="194"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${data.time}</span>
${document.cosmicCat.Template.Buttons.addTo(data.id)}
</a>
<div class="browse-item-content">
<h3 dir="ltr">
<a href="https://www.youtube.com/watch?v=${data.id}" title="" class="yt-uix-sessionlink" data-sessionlink="">${data.title}</a>
</h3>
<div class="browse-item-info">
<div class="metadata-line">
<span class="viewcount">${data.views}</span>
<span class="metadata-separator">|</span>
<span class="video-date-added">${data.upload}</span>
</div>
<a href="${(_a = data.owner) === null || _a === void 0 ? void 0 : _a.url}/featured" class="yt-uix-sessionlink yt-user-name" data-sessionlink="" dir="ltr">${(_b = data.owner) === null || _b === void 0 ? void 0 : _b.name}</a>
</div>
</div>
</div>`;
}
};
var Channels3Main = (data) => {
return `<div id="content">
<div id="branded-page-default-bg" class="ytg-base">
<div id="branded-page-body-container" class="ytg-base clearfix enable-fancy-subscribe-button">
${document.cosmicCat.Channels.isOwner() ? document.cosmicCat.Template.Channel.Channels3.creatorBar.Main(data) : ""}
${document.cosmicCat.Template.Channel.Channels3.Header(data)}
${document.cosmicCat.Template.Channel.Channels3.Content(data)}
</div>
${data.header.bannerBg ? `
<style>
#branded-page-body-container {
background-color: #111111;
background-image: url(${data.header.bannerBg});
background-repeat: no-repeat;
background-position: center top;
}
</style>
` : ""}
</div>
</div>`;
};
var Channels3Header = (data) => {
var _a, _b, _c, _d, _e, _f, _g;
return `<div id="branded-page-header-container" class="ytg-wide banner-displayed-mode">
<div id="branded-page-header" class="ytg-wide">
<div id="channel-header-main">
<div class="upper-section clearfix">
<a href="${window.location.pathname}">
<span class="channel-thumb context-image-container" data-context-image="${data.header.avatar}">
<span class="video-thumb ux-thumb yt-thumb-square-60">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.header.avatar}" alt="${data.header.avatar}" width="60"><span class="vertical-align"></span>
</span>
</span>
</span>
</span>
</a>
<div class="upper-left-section">
<h1 class="context-source-container" data-context-source="${data.header.name}">
<span class="qualified-channel-title">${data.header.name}</span>
</h1>
</div>
<div class="upper-left-section">
${document.cosmicCat.Template.Buttons.Subscribe(data.header.id)}
</div>
<div class="upper-right-section">
<div class="header-stats">
${document.cosmicCat.Channels.isOwner() ? `<a href="https://studio.youtube.com/channel/${data.header.id}/analytics/tab-overview/period-default" class="stat-entry">` : `<div class="stat-entry">`}
<span class="stat-value">${((_a = data === null || data === void 0 ? void 0 : data.info) === null || _a === void 0 ? void 0 : _a.subs) || ((_b = data === null || data === void 0 ? void 0 : data.header) === null || _b === void 0 ? void 0 : _b.subscriberCount)}</span>
<span class="stat-name">subscribers</span>
${document.cosmicCat.Channels.isOwner() ? `</a>` : `</div>`}
${document.cosmicCat.Channels.isOwner() ? `<a href="https://studio.youtube.com/channel/${data.header.id}/analytics/tab-overview/period-default" class="stat-entry">` : `<div class="stat-entry">`}
<span class="stat-value">${((_d = (_c = data === null || data === void 0 ? void 0 : data.info) === null || _c === void 0 ? void 0 : _c.fields) === null || _d === void 0 ? void 0 : _d.views) || ((_f = (_e = data === null || data === void 0 ? void 0 : data.header) === null || _e === void 0 ? void 0 : _e.fields) === null || _f === void 0 ? void 0 : _f.views)}</span>
<span class="stat-name">video views</span>
${document.cosmicCat.Channels.isOwner() ? `</a>` : `</div>`}
</div>
<span class="valign-shim"></span>
</div>
</div>
<div class="channel-horizontal-menu clearfix">
<ul role="tablist">
<li role="presentation" ${document.cosmicCat.Channels.isCurrentChannelTab("featured") ? "class=\"selected\"" : ""}>
<a href="./featured" class="gh-tab-100" role="tab" aria-selected="${document.cosmicCat.Channels.getCurrentChannelTab("featured") ? "true" : "false"}">${localizeString("channels.3.header.tabs.featured")}</a>
</li>
<li role="presentation" ${document.cosmicCat.Channels.getCurrentChannelTab().match(/videos|playlists|community/) ? "class=\"selected\"" : ""}>
<a href="${((_g = document.cosmicCat.Utils.browseTabs.find(ytInitialData, "videos")) === null || _g === void 0 ? void 0 : _g.tabRenderer) ? "./videos" : "./playlists"}" class="gh-tab-101" role="tab" aria-selected="${document.cosmicCat.Channels.getCurrentChannelTab().match(/videos|playlists/) ? "true" : "false"}">${localizeString("channels.3.header.tabs.videos")}</a>
</li>
</ul>
<form id="channel-search" class="" action="${window.location.pathname}">
<input name="query" type="text" autocomplete="off" class="search-field label-input-label" maxlength="100" placeholder="${localizeString("channels.3.header.tabs.search")}" value="">
<button class="search-btn" type="submit">
<span class="search-btn-content">Search</span>
</button>
<a class="search-dismiss-btn" href="${window.location.pathname}?view=0">
<span class="search-btn-content">Clear</span>
</a>
</form>
</div>
</div>
</div>
</div>`;
};
var Channels3Content = () => {
return `<div id="branded-page-body">
<div class="channel-tab-content channel-layout-two-column selected everything-template">
<div class="tab-content-body">
</div>
</div>
</div>`;
};
var Channels3PrimaryPaneFeatured = {
Main: () => {
return `<div class="primary-pane"></div>`;
},
featuredVideo: (data, d) => {
var _a;
return `<div class="channels-featured-video channel-module yt-uix-c3-module-container has-visible-edge">
<div id="player-api"></div>
<div class="channels-video-player player-root" data-video-id="1${data.id}" style="overflow: hidden;" data-swf-config=""></div>
<div class="channels-featured-video-details yt-tile-visible clearfix">
<h3 class="title">
<a href="http://www.youtube.com/watch?v=${data.id}" class="yt-uix-sessionlink" data-sessionlink="ei=CJXfprr5i7QCFScVIQodyVre8w%3D%3D&feature=plcp">${data.title}</a>
<div class="view-count-and-actions">
<div class="view-count">
<span class="count">${document.cosmicCat.Utils.deabreviateCnt((_a = data.views) === null || _a === void 0 ? void 0 : _a.split(" ")[0])}</span> views
</div>
</div>
</h3>
<p class="channels-featured-video-metadata">
<span>by ${d.name}</span>
<span class="created-date">${data.upload}</span>
</p>
</div>
</div>`;
},
playlist: () => {
return `<div class="playlists-wide channel-module yt-uix-c3-module-container">
<div class="module-view">
<h2>Featured Playlists</h2>
<div class="playlist yt-tile-visible yt-uix-tile">
<div class="playlist-metadata">
<h3 dir="ltr">
<a class="yt-uix-tile-link" href="/playlist?list=PLB152C3F078759BF6&feature=plcp">Trending Videos of the Week (1/14)</a>
</h3>
<p class="description" dir="ltr">See 11 of this week's top trending videos from YouTube.com/Trends</p>
</div>
<a class="yt-uix-contextlink play-all yt-uix-sessionlink" href="//www.youtube.com/watch?v=SKVcQnyEIT8&list=PLB152C3F078759BF6&feature=plcp" data-sessionlink="context=C40b03a5FDvjVQa1PpcFMfMNMbMOtv57rhWW-JBvg6eXMc319H4IY%3D">
<span class="playlist-thumb-strip playlist-thumb-strip-350">
<span class="videos videos-5 vertical-cutoff">
<span class="clip">
<span class="centering-offset">
<span class="centering">
<span class="ie7-vertical-align-hack"> </span><img src="//i4.ytimg.com/vi/SKVcQnyEIT8/default.jpg" data-thumb="//i4.ytimg.com/vi/SKVcQnyEIT8/default.jpg" alt="" class="thumb" data-group-key="thumb-group-0"></span>
</span>
</span><span class="clip">
<span class="centering-offset">
<span class="centering">
<span class="ie7-vertical-align-hack"> </span><img src="//i2.ytimg.com/vi/qX6UhgboDgc/default.jpg" data-thumb="//i2.ytimg.com/vi/qX6UhgboDgc/default.jpg" alt="" class="thumb" data-group-key="thumb-group-0"></span>
</span>
</span><span class="clip">
<span class="centering-offset">
<span class="centering">
<span class="ie7-vertical-align-hack"> </span><img src="//i2.ytimg.com/vi/1IAhDGYlpqY/default.jpg" data-thumb="//i2.ytimg.com/vi/1IAhDGYlpqY/default.jpg" alt="" class="thumb" data-group-key="thumb-group-0"></span>
</span>
</span><span class="clip">
<span class="centering-offset">
<span class="centering">
<span class="ie7-vertical-align-hack"> </span><img src="//i2.ytimg.com/vi/ElER4dZSaOs/default.jpg" data-thumb="//i2.ytimg.com/vi/ElER4dZSaOs/default.jpg" alt="" class="thumb" data-group-key="thumb-group-0"></span>
</span>
</span><span class="clip">
<span class="centering-offset">
<span class="centering">
<span class="ie7-vertical-align-hack"> </span><img src="//i3.ytimg.com/vi/f-x8t0JOnVw/default.jpg" data-thumb="//i3.ytimg.com/vi/f-x8t0JOnVw/default.jpg" alt="" class="thumb" data-group-key="thumb-group-0"></span>
</span>
</span>
</span>
<span class="resting-overlay">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="play-button" alt="Play all"><span class="video-count-box">11 videos</span>
</span>
<span class="hover-overlay">
<span class="play-all-container">
<strong><img src="//s.ytimg.com/yts/img/ui/playlist_thumb_strip/mini-play-all-vflZu1SBs.png" alt="">Play all</strong>
</span>
</span>
</span>
</a>
</div>
<a class="view-all-link" href="/web/20121025230635/http://www.youtube.com/user/YouTube/videos?view=1">view all
<img src="//web.archive.org/web/20121025230635im_/http://s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
</a>
</div>
</div>`;
}
};
var Channels3PrimaryPaneBrowseVideos = {
Main: (data) => {
var _a, _b, _c;
return `<div class="primary-pane">
<div class="channel-browse">
<div class="browse-heading channels-browse-gutter-padding">
<div id="channels-browse-header" class="clearfix">
<div id="browse-view-options">
<button type="button" class="flip channels-browse-options yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-menu-id="browse-view-options-menu" role="button" aria-pressed="false" aria-expanded="false">
<span class="yt-uix-button-content">View </span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
</button>
<div id="browse-view-options-menu" class="channel-nav-item-dropdown yt-uix-button-menu yt-uix-button-menu-external hid" style="min-width: 69px; left: 605.833px; top: 313.5px; display: none;">
</div>
</div>
<ul>
${((_a = document.cosmicCat.Utils.browseTabs.find(ytInitialData, "videos")) === null || _a === void 0 ? void 0 : _a.tabRenderer) ? `
<li class="channels-browse-filter ${document.cosmicCat.Channels.isCurrentChannelTab("videos") ? "selected" : ""}">
<a href="./videos">Uploads</a>
</li>
` : ""}
${((_b = document.cosmicCat.Utils.browseTabs.find(ytInitialData, "playlists")) === null || _b === void 0 ? void 0 : _b.tabRenderer) ? `
<li class="channels-browse-filter ${document.cosmicCat.Channels.isCurrentChannelTab("playlists") ? "selected" : ""}">
<a href="./playlists">Playlists</a>
</li>
` : ""}
${((_c = document.cosmicCat.Utils.browseTabs.find(ytInitialData, "community")) === null || _c === void 0 ? void 0 : _c.tabRenderer) ? `
<li class="channels-browse-filter ${document.cosmicCat.Channels.isCurrentChannelTab("community") ? "selected" : ""}">
<a href="./community">Feed</a>
</li>
` : ""}
</ul>
</div>
<div id="channel-feed-post-form">
</div>
<div class="yt-horizontal-rule channel-section-hr"><span class="first"></span><span class="second"></span><span class="third"></span></div>
</div>
<ul class="channels-browse-content-grid clearfix channels-browse-gutter-padding context-data-container">
</ul>
<div class="channels-browse-gutter-padding"></div>
</div>
</div>`;
},
Navigation: () => {
return `<div class="yt-uix-pager" role="navigation">
<a class="yt-uix-button yt-uix-sessionlink yt-uix-pager-page-num yt-uix-pager-button yt-uix-button-toggled yt-uix-button-default" data-page="1" aria-label="Go to page 1" data-sessionlink="ei=CPyLrL_cnbICFRgJIQod5QyJsA%3D%3D">
<span class="yt-uix-button-content">1</span></a>
<a class="yt-uix-button yt-uix-sessionlink yt-uix-pager-next yt-uix-pager-button yt-uix-button-default" data-page="2" id="next-btn" onclick="document.cosmicCat.Channels.Channels3.Pagination.next(this.getAttribute('data-token'), this.getAttribute('data-page'))" data-sessionlink="ei=CPyLrL_cnbICFRgJIQod5QyJsA%3D%3D">
<span class="yt-uix-button-content">Next »</span></a>
</div>`;
},
activityFeed: () => {
return `<div class="activity-feed">
<div class="feed-list-container context-data-container">
<div class="feed-item-list">
<ul></ul>
<button type="button" class="yt-uix-load-more load-more-button yt-uix-button yt-uix-button-default" onclick=";return false;" data-uix-load-more-href="/channel_ajax?action_load_more_feed_items=1&activity_view=1&channel_id=UCBR8-60-B28hp2BmDPdntcQ&paging=1352838391" role="button"><span class="yt-uix-button-content">Load More </span></button>
</div>
</div>
</div>`;
},
listItem: {
videos: (data) => {
return `<li class="channels-content-item">
<span class="context-data-item" data-context-item-title="${data.title}" data-context-item-type="video" data-context-item-time="${data.time}" data-context-item-user="" data-context-item-id="${data.id}" data-context-item-views="${data.views}">
<a href="https://www.youtube.com/watch?v=${data.id}" class="ux-thumb-wrap yt-uix-sessionlink yt-uix-contextlink contains-addto spf-link" data-sessionlink="ei">
<span class="video-thumb ux-thumb yt-thumb-default-194">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="Thumbnail" width="194"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${data.time}</span>
${document.cosmicCat.Template.Buttons.addTo(data.id)}
</a>
<a href="https://www.youtube.com/watch?v=${data.id}" title="${data.title}" class="content-item-title spf-link yt-uix-sessionlink yt-uix-contextlink" dir="ltr" data-sessionlink="ei">${data.title}</a>
<span class="content-item-detail">
<span class="content-item-view-count">${data.views}</span><span class="metadata-separator">|</span><span class="content-item-time-created">${data.upload}</span>
</span>
</span>
</li>`;
},
sidethumb: (data) => {
return `<span class="sidethumb">
<span class="video-thumb ux-thumb yt-thumb-default-43">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnails[0].url}" alt="Thumbnail" data-thumb="${data.thumbnails[0].url}" data-group-key="thumb-group-0" width="43"><span class="vertical-align"></span>
</span>
</span>
</span>
</span>`;
},
playlists: (data) => {
let sideThumbs = "";
try {
for (let i = 0; i < data.sidethumbs.length; i++) {
sideThumbs += document.cosmicCat.Template.Channel.Channels3.primaryPane.browseVideos.listItem.sidethumb(data.sidethumbs[i]);
}
}
catch (_a) { }
return `<li class="channels-content-item">
<span class="context-data-item" data-context-item-title="${data.title}" data-context-item-count="8 videos" data-context-item-id="PLbpi6ZahtOH5-VjZPSkqc0JI118RXAcGU" data-context-item-type="playlist" data-context-item-videos="["SNc7vYXqtVg", "T7SwehyOh3c", "IQG-xM62tQg", "c8DaqgMPrmQ", "f4LhCv7RY4E"]">
<a href="${data.url}" class="yt-pl-thumb-link yt-uix-contextlink yt-uix-sessionlink" data-sessionlink="ei">
<span class="yt-pl-thumb">
<span class="video-thumb ux-thumb yt-thumb-default-194">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="Thumbnail" data-thumb="${data.thumbnail}" data-group-key="thumb-group-0" width="194"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="sidebar sidebar-height-109">
<span class="video-count-wrapper">
<span class="video-count-block">
<span class="count-label">${data.videos.totalNumber}</span>
<span class="text-label">videos</span>
</span>
</span>
<span class="side-thumbs">
${sideThumbs}
</span>
</span>
<span class="yt-pl-thumb-overlay">
<span class="yt-pl-thumb-overlay-content">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">Play all
</span>
</span>
</span>
</a>
<span class="content-item-detail">
<a class="content-item-title" href="https://www.youtube.com/playlist?list=${data.id}" dir="ltr">${data.title}</a>
<span class="content-item-view-count">${data.videos.text}</span>
<span class="metadata-separator">|</span>
<span class="content-item-time-created">${data.updated}</span>
</span>
</span>
</li>`;
},
community: (data) => {
return `<li>
<div class="feed-item-container channels-browse-gutter-padding" data-channel-key="${data.owner.id}">
<div class="feed-author-bubble-container">
<a href="https://www.youtube.com${data.owner.url}" class="feed-author-bubble">
<span class="feed-item-author">
<span class="video-thumb ux-thumb yt-thumb-square-28">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.owner.icon}" alt="" data-thumb="${data.owner.icon}" data-group-key="thumb-group-0" width="28"><span class="vertical-align"></span>
</span>
</span>
</span>
</span>
</a>
</div>
<div class="feed-item-main">
<div class="feed-item-header">
<span class="feed-item-actions-line">
<span class="feed-item-owner">
<a href="https://www.youtube.com${data.owner.url}?feature=plcp" class="yt-user-name">${data.owner.name}</a></span> posted
<span class="feed-item-time">${data.upload}</span>
<div class="feed-item-post">
<p>${data.description}</p>
</div>
</span>
</div>
</div>
</div>
<div class="feed-item-dismissal-notices">
<div class="feed-item-dismissal feed-item-dismissal-hide hid">This item has been hidden</div>
<div class="feed-item-dismissal feed-item-dismissal-uploads hid">In the future you will only see uploads from <span class="feed-item-owner"><a href="https://www.youtube.com${data.owner.url}?feature=plcp" class="yt-user-name">${data.owner.name}</a></span></div>
<div class="feed-item-dismissal feed-item-dismissal-all-activity hid">In the future you will see all activity from <span class="feed-item-owner"><a href="https://www.youtube.com${data.owner.url}?feature=plcp" class="yt-user-name">${data.owner.name}</a></span></div>
<div class="feed-item-dismissal feed-item-dismissal-unsubscribe hid">You have been unsubscribed from <span class="feed-item-owner"><a href="https://www.youtube.com${data.owner.url}?feature=plcp" class="yt-user-name">${data.owner.name}</a></span></div>
</div>
</li>`;
}
}
};
var Channels3SecondaryPane = {
Main: (data) => {
var _a;
return `<div class="secondary-pane">
<div class="user-profile channel-module yt-uix-c3-module-container">
<div class="module-view profile-view-module" data-owner-external-id="BR8-60-B28hp2BmDPdntcQ">
<h2>${localizeString("channels.3.body.secondaryPane.userProfile.about", (_a = data === null || data === void 0 ? void 0 : data.header) === null || _a === void 0 ? void 0 : _a.name)}</h2>
${document.cosmicCat.Template.Channel.Channels3.secondaryPane.firstSection.Main(data)}
${document.cosmicCat.Template.Channel.Channels3.secondaryPane.createdBySection.Main(data)}
</div>
</div>`;
},
firstSection: {
Main: (data) => {
var _a, _b;
return `<div class="section first">
<div class="user-profile-item profile-description">
<p>${(_b = (_a = data === null || data === void 0 ? void 0 : data.info) === null || _a === void 0 ? void 0 : _a.fields) === null || _b === void 0 ? void 0 : _b.description}</p>
</div>
<div class="user-profile-item profile-socials">
</div>
<hr class="yt-horizontal-rule">
</div>`;
},
socialLink: (data) => {
var _a, _b;
return `<div class="yt-c3-profile-custom-url field-container">
<a href="https://${data.link.content}" rel="me nofollow" target="_blank" title="${data.title.content}" class="yt-uix-redirect-link">
<img src="//www.google.com/s2/favicons?sz=64&domain=${(_b = (_a = data.link.content) === null || _a === void 0 ? void 0 : _a.split("/")) === null || _b === void 0 ? void 0 : _b[0]}" class="favicon" alt="${data.title.simpleText}"><span class="link-text">${data.title.content}</span>
</a>
</div>`;
}
},
createdBySection: {
Main: (data) => {
var _a, _b, _c;
return `<div class="section created-by-section">
<div class="user-profile-item">${localizeString("channels.3.body.secondaryPane.userProfile.createdBy.by", ((_a = data.header) === null || _a === void 0 ? void 0 : _a.gameBy) || ((_b = data.header) === null || _b === void 0 ? void 0 : _b.tag) || ((_c = data.header) === null || _c === void 0 ? void 0 : _c.name))}</div>
<ul>
${document.cosmicCat.Template.Channel.Channels3.secondaryPane.createdBySection.Item(data.info)}
</ul>
</div>`;
},
Item: (data) => {
let fields = "";
for (const info in data.fields) {
if (data.fields[info] && !info.match(/description|views/i)) {
fields += `<li class="user-profile-item">
<span class="item-name">${localizeString("channels.2.modules.userProfile.cards." + info)}</span>
<span class="value">${data.fields[info]}</span>
</li>`;
}
}
return fields;
}
}
};
var Channels3CreatorBar = {
Main: (data) => {
return `<div id="watch7-creator-bar" class="clearfix yt-uix-button-panel" style="width: 970px;margin-left: auto;margin-right: auto;margin-top: 10px">
<ul id="watch7-creator-bar-nav-buttons">
<li class="creator-bar-item">
<a href="https://www.youtube.com/analytics" class="yt-uix-button yt-uix-sessionlink yt-uix-button-dark yt-uix-button-size-default" data-sessionlink="ei=PAqqU5WaN4278AO4hoCACg&feature=mhsn">
<span class="yt-uix-button-content">${localizeString("channels.3.creatorBar.analytics")}</span>
</a>
</li>
<li class="creator-bar-item">
<a href="/my_videos" class="yt-uix-button yt-uix-sessionlink yt-uix-button-dark yt-uix-button-size-default" data-sessionlink="ei=PAqqU5WaN4278AO4hoCACg&feature=mhsn">
<span class="yt-uix-button-content">${localizeString("channels.3.creatorBar.videomanager")}</span>
</a>
</li>
</ul>
<ul id="watch7-creator-bar-edit-buttons">
<li class="creator-bar-item">
<a href="https://studio.youtube.com/channel/${data.header.id}/editing/details" class="yt-uix-button yt-uix-sessionlink yt-uix-button-dark yt-uix-button-size-default" data-sessionlink="ei=PAqqU5WaN4278AO4hoCACg&feature=mhsn">
<span class="yt-uix-button-content">${localizeString("channels.3.creatorBar.settings")}</span>
</a>
</li>
</ul>
</div>`;
}
};
var Channels2Main = (data) => {
let customBranding = `
<style id="custom-branding">
#channel-body {
background-color: rgb(204, 204, 204);
background-image: url(${data.header.bannerBg});
background-repeat: no-repeat;
background-position: center top;
}
</style>
`;
return `<div id="channel-body" class="jsloaded">
<div id="channel-base-div">
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Main(data)}
${document.cosmicCat.Template.Channel.Channels2.moduleContainer.Main(data)}
</div>
</div>
${data.header.bannerBg ? customBranding : ""}
<style id="channels-2.0_urgent-button">
.yt-subscription-button {
height: 2.0833em !important;
width: 69px !important;
padding: 0 .5em !important;
color: #000 !important;
font-weight: bold !important;
border-color: #ecc101 !important;
background: #ffe971 !important;
background-image: none !important;
background-image: -moz-linear-gradient(top,#fff9c1,#fed81c) !important;
background-image: -webkit-gradient(linear,left top,left bottom,from(#fff9c1),to(#fed81c)) !important;
filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#fff9c1,endColorStr=#fed81c) !important;
}
.yt-subscription-button:hover {
border-color: #630 !important;
background: #ecc101 !important;
background-image: none !important;
background-image: -moz-linear-gradient(top,#fff9c1,#fed81c) !important;
background-image: -webkit-gradient(linear,left top,left bottom,from(#fff9c1),to(#fed81c)) !important;
filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#fff9c1,endColorStr=#fed81c) !important;
}
.yt-subscription-button .subscribe-label,
.yt-subscription-button .subscribed-label,
.yt-subscription-button .unsubscribe-label {
display: inline;
}
.yt-subscription-button .yt-uix-button-icon-wrapper,
.yt-subscription-button:not(.subscribed) .subscribed-label,
.yt-subscription-button:not(.subscribed) .unsubscribe-label,
.yt-subscription-button.subscribed .subscribe-label,
.yt-subscription-button.subscribed:not(:hover) .unsubscribe-label,
.yt-subscription-button.subscribed:hover .subscribed-label {
display: none;
}
.yt-subscription-button.subscribed {
padding: 0 !important;
}
</style>`;
};
var Channels2PlaylistNavigator = {
Main: (data) => {
return `<div id="user_playlist_navigator" class="outer-box yt-rounded">
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Header(data.header)}
<div id="subscribeMessage" class="hid"> </div>
<div id="subscription-button-module-menu" class="hid subscription-menu-expandable subscription-menu">
<div class="subscription-menu-not-logged-in">
<strong>
<a href="${document.cosmicCat.data.loginUrl}">Sign in</a> or <a href="https://www.youtube.com/signup">sign up</a> now!
</strong>
</div>
</div>
<div id="user_playlist_navigator-messages" class="hid"></div>
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.Main(data)}`;
},
Header: (data) => {
return `<div id="playnav-channel-header" class="inner-box-bg-color">
<div id="playnav-title-bar">
<div id="playnav-channel-name" class="outer-box-bg-color">
<div class="channel-thumb-holder outer-box-color-as-border-color">
<div class="user-thumb-semismall ">
<div>
<img src="${data.avatar}">
</div>
</div>
</div>
<div class="channel-title-container">
<div class="channel-title outer-box-color" id="channel_title" dir="ltr">${data.name}</div>
<div class="channel-title outer-box-color" style="font-size:11px" id="channel_base_title">${data.tag}'s Channel</div>
</div>
<div id="subscribe-buttons">
${document.cosmicCat.Template.Buttons.Subscribe(data.id)}
</div>
</div>
<div id="playnav-chevron"> </div>
</div>
<div id="playnav-navbar">
<table>
<tbody>
<tr>
<td>
<a class="navbar-tab inner-box-link-color ${document.cosmicCat.Channels.isCurrentChannelTab("videos") ? "navbar-tab-selected" : ""}" id="playnav-navbar-tab-uploads" href="javascript:;" onclick="document.cosmicCat.Channels.playnav.selectTab('videos', this);">Uploads</a>
</td>
<td>
<a class="navbar-tab inner-box-link-color ${document.cosmicCat.Channels.isCurrentChannelTab("playlists") ? "navbar-tab-selected" : ""}" id="playnav-navbar-tab-playlists" href="javascript:;" onclick="document.cosmicCat.Channels.playnav.selectTab('playlists', this);">Playlists</a>
</td>
</tr>
</tbody>
</table>
</div>
<div class="cb"></div>
</div>
`;
},
Content: {
Main: (data) => {
return `<div id="playnav-body" style="height: auto;">
<div id="playnav-player" class="playnav-player-container" style="height: 390px; visibility: visible; left: 0px;">
<div id="player-api"></div><div id="watch-player" class="player-root"></div>
</div>
<div id="playnav-playview" class="" style="display: block;">
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.Restricted(data)}
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.LeftPanel.Main(data)}
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.PlayPanel.Main(data)}
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.Loading()}
</div>
</div>`;
},
Restricted: (data) => {
return `<div id="playnav-player-restricted" class="inner-box-colors" style="display: none;">
<div id="playnav-inner-restricted">
<div id="playnav-restricted-title-div"><h3 id="playnav-restricted-title"></h3></div>
<div id="playnav-login-required" class="playnav-restricted-msg">
<p>You must be <a class="playnav-restricted-link" href="">logged in</a> to view this video.</p>
</div>
<div id="playnav-controversy" class="playnav-restricted-msg">
<p>The following content has been identified by the YouTube community as being potentially offensive or inappropriate. Viewer discretion is advised.
Please <a class="playnav-restricted-link" href="">confirm</a> that you wish to view this video.</p>
</div>
<div id="playnav-verify-age-for-age-gated" class="playnav-restricted-msg">
<p>This video or group may contain content that is inappropriate for some users, <a href="https://www.google.com/support/youtube/bin/answer.py?answer=186529" target="_blank">as determined by the video uploader.</a>
To view this video or group, please <a class="playnav-restricted-link" href="">click here</a> to sign in or sign up and verify that you are of the appropriate age.</p>
</div>
<div id="playnav-verify-age" class="playnav-restricted-msg">
<p>This video requires that you log in to verify your age.
Please <a class="playnav-restricted-link" href="">confirm</a> that you wish to view this video.</p>
</div>
<div id="playnav-unavailable" class="playnav-restricted-msg">
<p>This video is unavailable.</p>
</div>
<div id="playnav-custom-error-message" class="playnav-restricted-msg"></div>
</div>
</div>`;
},
LeftPanel: {
Main: (data) => {
return `<div id="playnav-left-panel" style="display: block;">
<div class="playnav-player-container"></div>
<div id="playnav-video-details">
<div id="playnav-bottom-links">
<div id="playnav-bottom-links-clip" class="playnav-bottom-links-clip">
<table>
<tbody>
<tr>
<td id="playnav-panel-tab-info" class="panel-tab-selected">
<table class="panel-tabs">
<tbody>
<tr>
<td class="panel-tab-title-cell">
<div class="playnav-panel-tab-icon" id="panel-icon-info" onmouseover="_addclass(_gel('playnav-panel-tab-info'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-info'), 'panel-tab-hovered')" onclick="playnav.selectPanel('info')"></div>
<div class="playnav-bottom-link" id="info-bottom-link">
<a href="javascript:;" onmouseover="_addclass(_gel('playnav-panel-tab-info'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-info'), 'panel-tab-hovered')" onclick="playnav.selectPanel('info')">Info</a>
</div>
<div class="spacer"> </div>
</td>
</tr>
<tr>
<td class="panel-tab-indicator-cell inner-box-opacity">
<div class="panel-tab-indicator-arrow"></div>
</td>
</tr>
</tbody>
</table>
</td>
<td id="playnav-panel-tab-favorite">
<table class="panel-tabs">
<tbody>
<tr>
<td class="panel-tab-title-cell">
<div class="playnav-panel-tab-icon" id="panel-icon-favorite" onmouseover="_addclass(_gel('playnav-panel-tab-favorite'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-favorite'), 'panel-tab-hovered')" onclick="playnav.selectPanel('favorite')"></div>
<div class="playnav-bottom-link" id="favorite-bottom-link">
<a href="javascript:;" onmouseover="_addclass(_gel('playnav-panel-tab-favorite'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-favorite'), 'panel-tab-hovered')" onclick="playnav.selectPanel('favorite')">Favorite</a>
</div>
<div class="spacer"> </div>
</td>
</tr>
<tr>
<td class="panel-tab-indicator-cell inner-box-opacity">
<div class="panel-tab-indicator-arrow"></div>
</td>
</tr>
</tbody>
</table>
</td>
<td id="playnav-panel-tab-share">
<table class="panel-tabs">
<tbody>
<tr>
<td class="panel-tab-title-cell">
<div class="playnav-panel-tab-icon" id="panel-icon-share" onmouseover="_addclass(_gel('playnav-panel-tab-share'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-share'), 'panel-tab-hovered')" onclick="playnav.selectPanel('share')"></div>
<div class="playnav-bottom-link" id="share-bottom-link">
<a href="javascript:;" onmouseover="_addclass(_gel('playnav-panel-tab-share'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-share'), 'panel-tab-hovered')" onclick="playnav.selectPanel('share')">Share</a>
</div>
<div class="spacer"> </div>
</td>
</tr>
<tr>
<td class="panel-tab-indicator-cell inner-box-opacity">
<div class="panel-tab-indicator-arrow"></div>
</td>
</tr>
</tbody>
</table>
</td>
<td id="playnav-panel-tab-flag">
<table class="panel-tabs">
<tbody>
<tr>
<td class="panel-tab-title-cell">
<div class="playnav-panel-tab-icon" id="panel-icon-flag" onmouseover="_addclass(_gel('playnav-panel-tab-flag'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-flag'), 'panel-tab-hovered')" onclick="playnav.selectPanel('flag')"></div>
<div class="playnav-bottom-link" id="flag-bottom-link">
<a href="javascript:;" onmouseover="_addclass(_gel('playnav-panel-tab-flag'), 'panel-tab-hovered')" onmouseout="_removeclass(_gel('playnav-panel-tab-flag'), 'panel-tab-hovered')" onclick="playnav.selectPanel('flag')">Flag</a>
</div>
<div class="spacer"> </div>
</td>
</tr>
<tr>
<td class="panel-tab-indicator-cell inner-box-opacity">
<div class="panel-tab-indicator-arrow"></div>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</div>
<div class="cb"></div>
<div class="playnav-video-panel inner-box-colors border-box-sizing">
<div id="playnav-video-panel-inner" class="playnav-video-panel-inner border-box-sizing" style="overflow: auto;">
</div>
<div id="playnav-panel-comments" class="hid"></div>
<div id="playnav-panel-favorite" class="hid"></div>
<div id="playnav-panel-share" class="hid scrollable"></div>
<div id="playnav-panel-playlists" class="hid"></div>
<div id="playnav-panel-flag" class="hid scrollable"></div>
</div>
</div>
</div>
</div>`;
},
Info: (data, owner) => {
return `<div id="playnav-panel-info" class="scrollable" style="display: block;">
<div id="channel-like-action">
<div id="channel-like-buttons">
<button class=" yt-uix-button yt-uix-tooltip" type="button" id="watch-like" onclick=";return false;" title="I like this" data-button-action="playnav.like" role="button">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-like" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="I like this">
<span class="yt-uix-button-content">Like </span>
</button>
<button class=" yt-uix-button yt-uix-tooltip yt-uix-button-empty" type="button" id="watch-unlike" onclick=";return false;" title="I dislike this" data-button-action="playnav.unlike" role="button">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-unlike" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="I dislike this"></button>
</div>
<form method="post" action="//www.youtube.com/watch_actions_Ajax" name="likeForm" class="hid">
<input type="hidden" name="action_like_video" value="1">
<input type="hidden" name="video_id" value="${data.id}">
<input name="session_token" type="hidden" value="jk7H8NNcOfnfqH-6En0oRy0yffx8MTMyNzU5Njg5NEAxMzI3NTEwNDk0"></form>
<form method="post" action="//www.youtube.com/watch_actions_Ajax" name="unlikeForm" class="hid">
<input type="hidden" name="action_dislike_video" value="1">
<input type="hidden" name="video_id" value="${data.id}">
<input name="session_token" type="hidden" value="jk7H8NNcOfnfqH-6En0oRy0yffx8MTMyNzU5Njg5NEAxMzI3NTEwNDk0"></form>
<div id="channel-like-logged-out" class="hid">
<strong>
<a href="${document.cosmicCat.data.loginUrl}">Sign in</a> or <a href="https://www.youtube.com/signup">sign up</a> now!
</strong>
</div>
<div id="channel-like-close" class="hid">
<div class="close">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="close-button" onclick="playnav.hideLike();"></div>
</div>
</div>
<div id="playnav-curvideo-title" class="inner-box-link-color" dir="ltr">
<a href="https://www.youtube.com/watch?v=${data.id}&feature=channel_video_title">${data.title}</a>
</div>
<div id="playnav-curvideo-info-line">From:
<span id="playnav-curvideo-channel-name">
<a href="https://www.youtube.com${owner.url}" class="yt-user-name" dir="ltr">${owner.name}</a>
</span>| <span dir="ltr">${data.upload}</span> | <span id="playnav-curvideo-view-count">${data.views}</span>
</div>
<div class="cb"></div>
<div id="channel-like-result" class="hid">
<div id="watch-actions-area" class="yt-rounded"> </div>
</div>
<div id="channel-like-loading" class="hid">${localizeString("global.loading.main")}</div>
<div class="cb"></div>
<div id="playnav-curvideo-description-container">
<div id="playnav-curvideo-description" dir="ltr">
${data.description}
<div id="playnav-curvideo-description-more-holder" style="display: block;">
<div id="playnav-curvideo-description-more" class="inner-box-bg-color">
... <a class="channel-cmd" href="javascript:;" onclick="document.cosmicCat.Channels.playnav.toggleFullVideoDescription(true)">(more info)</a>
</div>
<div class="cb"></div>
</div>
<span id="playnav-curvideo-description-less">
<a href="javascript:;" class="channel-cmd" onclick="document.cosmicCat.Channels.playnav.toggleFullVideoDescription(false)">(less info)</a>
</span>
</div>
</div>
<a href="https://www.youtube.com/watch?v=${data.id}" id="playnav-watch-link" onclick="playnav.goToWatchPage()">View comments, related videos, and more</a>
<div id="playnav-curvideo-controls"></div>
<div class="cb"></div>
<script>
if (_gel('playnav-curvideo-description').offsetHeight > 28) {
_gel('playnav-curvideo-description-more-holder').style.display = 'block';
}
</script>
</div>`;
}
},
PlayPanel: {
Main: (data) => {
return `<div id="playnav-play-panel">
<div id="playnav-play-content" style="height: 601px;">
${document.cosmicCat.Template.Channel.Channels2.playlistNavigator.Content.PlayPanel.Holder.Main()}
</div>
</div>`;
},
Holder: {
Main: () => {
const chk = (window.location.hash == "#p/p" ? "playlists" : "uploads");
return `<div class="playnav-playlist-holder" id="playnav-play-playlist-${chk}-holder" style="display: block;">
<div id="playnav-play-${chk}-scrollbox" class="scrollbox-wrapper inner-box-colors">
<div class="scrollbox-content playnav-playlist-non-all">
<div class="scrollbox-body" style="height: 585px;">
<div class="outer-scrollbox">
<div id="playnav-play-${chk}-items" class="inner-scrollbox">
<div id="playnav-play-${chk}-page-0" class="scrollbox-page loaded ${chk}-rows-50">
</div>
</div>
</div>
</div>
</div>
</div>
</div>`;
},
videos: (data) => {
return `<div id="playnav-video-play-uploads-6-${data.id}" class="playnav-item playnav-video">
<div style="display:none" class="encryptedVideoId">${data.id}</div>
<div id="playnav-video-play-uploads-6-${data.id}-selector" class="selector"></div>
<div class="content">
<div class="playnav-video-thumb">
<a href="https://www.youtube.com/watch?v=${data.id}" class="ux-thumb-wrap contains-addto">
<span class="video-thumb ux-thumb-96">
<span class="clip">
<img src="//i.ytimg.com/vi/${data.id}/hqdefault.jpg" alt="Thumbnail" class="" onclick="playnav.playVideo('uploads','6','${data.id}');return false;" title="${data.title}">
</span>
</span>
<span class="video-time">${data.time}</span>
${document.cosmicCat.Template.Buttons.addTo(data.id)}
</a>
</div>
<div class="playnav-video-info">
<a href="https://www.youtube.com/watch?v=${data.id}" class="playnav-item-title ellipsis" onclick="playnav.playVideo('uploads','6','${data.id}');return false;" id="playnav-video-title-play-uploads-6-${data.id}">
<span dir="ltr">${data.title}</span>
</a>
<div class="metadata">
<span dir="ltr">${data.views} - ${data.upload}</span>
</div>
<div style="display:none" id="playnav-video-play-uploads-6">${data.id}</div>
</div>
</div>
</div>`;
},
playlists: (data) => {
return `<div class="playnav-item playnav-playlist">
<div style="display:none" class="encryptedPlaylistId">${data.id}</div>
<div class="selector"></div>
<div class="content">
<div class="playnav-playlist-thumb">
<div class="vCluster120WideEntry">
<div class="vCluster120WrapperOuter">
<div class="vCluster120WrapperInner">
<a id="video-url-${data.id}" href="javascript:;" rel="nofollow" onclick="playnav.selectPlaylist('user', '${data.id}')">
<img title="" src="${data.thumbnail}" class="vimgCluster120" alt="">
<span class="video-corner-text" id="video-corner-text-${data.id}">${data.videos.text}</span>
</a>
</div>
</div>
</div>
</div>
<div class="playnav-playlist-info">
<a href="javascript:;" class="playnav-item-title ellipsis" onclick="playnav.selectPlaylist('user', '${data.id}')" dir="ltr">${data.title}</a>
<div class="metadata">
${data.updated}<br>
<a href="javascript:;" onclick="playnav.selectPlaylist('user', '${data.id}')" class="more-info">more info</a>
</div>
</div>
<div class="cb"></div>
</div>
</div>`;
}
}
},
Loading: () => {
return `<div id="playnav-play-loading" class="loading" style="display: block">
<div class="cover outer-box-bg-color"></div>
<div class="image-holder">
<div class="image-holder-middle">
<div class="image-holder-inner">
<img src="//s.ytimg.com/yt/img/icn_loading_animated-vflff1Mjj.gif" alt="${localizeString("global.loading.main")}">
</div>
</div>
</div>
</div>`;
}
}
};
var Channels2ModuleContainer = {
Main: (data) => {
return `<div class="outer-box" id="main-channel-content" style="z-index: 0">
<div class="left-column" id="main-channel-left"></div>
<div class="right-column" id="main-channel-right"></div>
<div class="cb"></div>
</div>`;
},
profile: (data) => {
return `<div class="inner-box" id="module-profile">
<div style="float:left;padding:0 4px 4px 0" class="link-as-border-color">
<div class="user-thumb-xlarge">
<div>
<a href="${data.url}">
<img src="${data.avatar}">
</a>
</div>
</div>
</div>
<div style="float:left;width:170px">
<div class="box-title title-text-color" title="${data.name}" style="float:none;padding-left:4px;margin-top:-2px;width:170px;overflow:hidden;font-size:111%">
<span class="yt-user-name" dir="ltr">${data.name}</span>
</div>
<div style="whitespace:no-wrap;position:relative;width:170px;">
<div>
${document.cosmicCat.Template.Buttons.Subscribe(data.id)}
<div class="cb"></div>
</div>
<div style="padding:4px">
<a href="#" onclick="add_friend('${data.id}'); return false;">Add as Contact</a>
|
<span class="nowrap">
<a id="aProfileBlockUser" href="#" onclick="yt.www.watch.user.blockUserLinkByUsername('${data.id}', true);return false;">Block User</a>
| </span>
<span class="nowrap">
<a id="aProfileSendMsg" href="https://www.youtube.com/inbox?to_user_ext_ids=${data.id}&action_compose=1">Send Message</a>
</span>
</div>
</div>
</div>
<div id="position-edit-subscription-in-channel"></div>
<div class="cb"></div>
</div>`;
},
userInfo: (data) => {
let fields = "";
for (const info in data.fields) {
if (data.fields[info]) {
fields += `<div class="show_info outer-box-bg-as-border">
<div class="profile-info-label">${localizeString("channels.2.modules.userProfile.cards." + info)}</div>
<div class="profile-info-value fn" id="profile_show_${info}">${data.fields[info]}</div>
<div class="cb"></div>
</div>`;
}
}
return `<div class="inner-box" id="user_profile">
<div class="box-title title-text-color">${localizeString("channels.2.modules.userProfile.title")}</div>
<div class="box-editor"></div>
<div class="cb"></div>
<div id="user_profile-body">
<div id="user_profile-messages" class="hid"></div>
<div class="edit_info spacer"> </div>
<div class="profile_info vcard">
<div class="show_info outer-box-bg-as-border">
<div class="profile-info-label">${localizeString("channels.2.modules.userProfile.cards.name")}</div>
<div class="profile-info-value fn" id="profile_show_name">${data.name}</div>
<div class="cb"></div>
</div>
${fields}
</div>
</div>
<div class="cb"></div>
</div>`;
}
};
var Channels2Stylesheet = () => {
return `<style>#channel-body {background-color: rgb(204, 204, 204)}
.outer-box, #playnav-channel-name {background-color: rgb(153, 153, 153)}
.outer-box-bg-color, .inner-box-colors, .inner-box, .inner-box-bg-color {background-color: rgb(238, 238, 255)}
#playnav-chevron {border-left-color: rgb(153, 153, 153);}
.panel-tab-selected .panel-tab-indicator-arrow {border-bottom-color: rgb(238, 238, 255) !important}</style>`;
};
var Channels1 = {
// forgot to finish this
// accidentally kept the option enabled, whoops.
Main: (data) => {
return `<div id="baseDiv">
<div class="profileTitleLinks">
<div id="profileSubNav">
<a href="${data.header.url}/videos">Videos</a>
<span class="delimiter">|</span>
<a href="${data.header.url}/playlists">Playlists</a>
</div>
</div>
<div id="profile-side-content">
${document.cosmicCat.Template.Channel.Channels1.sideCon.userPro(data)}
${document.cosmicCat.Template.Channel.Channels1.sideCon.userConn(data)}
</div>
<div id="profile-main-content">
${document.cosmicCat.Template.Channel.Channels1.mainCon.userVideos.Main(data)}
</div>
<div style="clear:both"></div>
</div>`;
},
sideCon: {
userPro: (data) => {
return `<div class="profile-box profile-highlightbox">
<div class="box-head">
<div class="box-fg">
<div class="headerTitleEdit">
<div class="headerTitleRight">
<script type="text/javascript">
var watchUsername = 'YouTube';
var subscribeaxc = '';
var isLoggedIn = false ;
</script>
<div id="subscribeDiv">
<a class="action-button" onclick="subscribe(watchUsername, subscribeaxc, true); urchinTracker('/Events/SUB_click/Profile/YouTube'); return false;" title="subscribe to YouTube's videos">
<span class="action-button-leftcap"></span>
<span class="action-button-text">Subscribe</span>
<span class="action-button-rightcap"></span>
</a>
</div>
<div id="unsubscribeDiv" class="hid">
<a class="action-button inactive" onclick="unsubscribe(watchUsername, subscribeaxc); return false;">
<span class="action-button-leftcap"></span>
<span class="action-button-text">Unsubscribe</span>
<span class="action-button-rightcap"></span>
</a>
</div>
</div>
<div class="headerTitleLeft">YouTube Channel</div>
</div>
</div>
<div class="box-bg"></div>
</div>
<div class="box-body">
<div class="box-fg">
<div id="subscribeMessage">Please login to perform this operation.</div>
<div class="hid">See related Channels</div>
<div class="floatL">
<div class="user-thumb-xlarge">
<img src="${data.header.avatar}" alt="${data.header.name}">
</div>
</div>
<div style="float:left;margin-left:5px;width:180px;">
<div class="largeTitles">
<strong>${data.header.name}</strong>
</div>
<div class="padT3">
<div class="smallText">Joined: <strong>${data.info.fields.joined}</strong></div>
<div class="smallText">Subscribers: <strong>${data.header.subscriberCount}</strong></div>
<div class="smallText">Channel Views: <strong>${data.info.fields.views}</strong></div>
</div>
</div>
<div style="clear:both"></div>
<br>
<div class="padT5 profileAssets">
<br>
<img src="//www.youtube.com/img/flags/en_US_globe.gif" class="currentFlag" width="17">
<br>
</div>
<div class="flaggingText">
<a href="http://www.youtube.com/flag_user?username=YouTube&action=report_profile_image" onclick="javascript:getSimpleXR('/flag_user?username=YouTube&action=report_profile_image&format=xml', showConfMsg, this);return false;">Report</a> profile image violation</div>
</div>
<div class="box-bg"></div>
</div>
</div>`;
},
userConn: (data) => {
return `<div class="profile-box">
<div class="box-head">
<div class="box-fg">
<div class="headerTitle">Connect with YouTube</div>
</div>
<div class="box-bg"></div>
</div>
<div class="box-body">
<div class="box-fg">
<table width="100%" cellspacing="0" cellpadding="3" border="0">
<tbody>
<tr>
<td width="110" valign="middle" align="right"></td>
<td valign="top" align="left">
<table class="actionsTable">
<tbody>
<tr class="actionsTable">
<td class="actionsTable">
<div class="smallText">
<a id="aProfileSendMsg" href="https://www.youtube.com/outbox?to_user=YouTube">
<img src="//s.ytimg.com/yt/img/pixel-vfl73.gif" id="profileSendMsg" class="icnProperties" alt="Send Message">Send Message</a>
</div>
<div class="smallText">
<a id="aProfileAddComment" href="https://www.youtube.com/profile_comment_post?user=YouTube">
<img src="//s.ytimg.com/yt/img/pixel-vfl73.gif" id="profileAddComment" class="icnProperties" alt="Add Comment">Add Comment</a>
</div>
<div class="smallText">
<a id="aProfileFwdMember" href="javascript:share_profile()">
<img src="//s.ytimg.com/yt/img/pixel-vfl73.gif" id="profileFwdMember" class="icnProperties" alt="Share Channel">Share Channel</a>
</div>
<div class="smallText">
</div>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
<tr>
<td colspan="2">
<div class="marB3 alignC">
<a href="http://www.youtube.com/YouTube">http://www.youtube.com/</a></div>
</td>
</tr>
</tbody></table>
</div>
<div class="box-bg"></div>
</div>
</div>`;
}
},
mainCon: {
userFeatured: (data) => {
return `<div class="profileEmbedVideo" id="user_featured">
<div id="profile-player-div">
</div>
<script type="text/javascript">
var swfArgs = {"el": "profilepage", "BASE_YT_URL": "https://web.archive.org/web/20090609053526/http://www.youtube.com/", "iv_allow_external_links": 1, "iv_storage_server": "https://web.archive.org/web/20090609053526/http://www.google.com/reviews/y/", "rs": "1", "ss": "1", "iv_module": "https://web.archive.org/web/20090609053526/http://s.ytimg.com/yt/swf/iv_module-vfl97100.swf", "video_id": "YZsMgrxGaMA", "l": 1602, "sk": "Lca8SIZeGn-Y2DgJIDvvn8FvtgWFupcIC", "fmt_map": "35/640000/9/0/115,34/0/9/0/115,5/0/7/0/0", "vq": null, "t": "vjVQa1PpcFPay5dnEQSWJoNjhZX631p1fhKtiXUwpOw=", "hl": "en", "plid": "AARr47nU67ILcwn5", "keywords": "Michael%2CBuckley%2CWHATTHEBUCKSHOW%2CYouTube%2Csuccess%2Ctips", "cr": "ES", "sn": "1"};
var swfUrl = canPlayV9Swf() ? 'https://web.archive.org/web/20090609053526/http://s.ytimg.com/yt/swf/watch-vfl101887.swf' : 'https://web.archive.org/web/20090609053526/http://s.ytimg.com/yt/swf/watch_v8-vfl101887.swf';
var watchGamUrl = null;
var watchDCUrl = null;
var watchIsPlayingAll = false;
var watchSetWmode = false;
var useWmodeDirect = false;
var ad_eurl = null;
writeMoviePlayer("profile-player-div");
</script>
<center>
<div class="profile-box profileEmbedVideoInfo" style="margin: 10px 0px 15px 0px;">
<div class="box-body">
<div class="box-fg">
<div class="vtitle">
<strong>
<a href="https://www.youtube.com/watch?v=YZsMgrxGaMA">
Michael Buckley's Secrets to YouTube Success
</a>
</strong>
</div>
<div class="vfacets">
From:
<a href="/web/20090609053526/http://www.youtube.com/user/YouTube" title="YouTube">YouTube</a>
<br>
Views: 80,402
<br>
Comments:
<a href="/web/20090609053526/http://www.youtube.com/comment_servlet?all_comments&v=YZsMgrxGaMA">403</a>
</div>
</div>
<div class="box-bg"></div>
</div>
</div>
</center>
</div>`;
},
userVideos: {
Main: (data) => {
return `<div class="profile-box">
<div class="box-head">
<div class="box-fg">
<div class="headerTitle">
<div class="headerTitleRight">
</div>
<span>Videos (<a href="/web/20080612190422/http://www.youtube.com/profile_videos?user=YouTube" class="headersSmall">34</a>)</span>
</div>
</div>
<div class="box-bg"></div>
</div>
<div class="box-body">
<div class="box-fg">
<div style="padding: 3px;">
<div class="clear"></div>
</div>
<div id="profileVideos" style="margin-left:12px;text-align: center;">
<table height="121" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="alignTop padTsm">
<img src="//s.ytimg.com/yt/img/pixel-vfl73.gif" class="btn_vscroll_lt_18x106 hand" onclick="fadeOldImage('profile_videos','4');shiftLeft('profile_videos')" id="vbrol"></td>
<td style="padding-top:4px">
<table style="background-color: XXXXXX;" width="500" height="121" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="border-bottom:none;" id="vids">
</td>
</tr>
</tbody>
</table>
</td>
<td class="alignTop padTsm">
<img src="//s.ytimg.com/yt/img/pixel-vfl73.gif" class="btn_vscroll_rt_18x106 hand" onclick="fadeOldImage('profile_videos','4');shiftRight('profile_videos');" id="vbror"></td>
</tr>
</tbody>
</table>
</div>
<div id="loadingDiv" class="marT18 alignC" style="display:none;height:500px;">
<br><br>
<img src="//s.ytimg.com/yt/img/icn_loading_animated-vfl24663.gif">
<br><br>
</div>
</div>
<div class="box-bg"></div>
</div>
</div>`;
},
videos: (data) => {
return `<div class="videobarthumbnail_block" id="div_profile_videos_0">
<center>
<div class="video-thumb-medium">
<a id="href_profile_videos_0" href="https://www.youtube.com/watch?v=${data.id}">
<img id="img_profile_videos_0" src="https://i.ytimg.com/vi/${data.id}/default.jpg" onload="opacity('img_profile_videos_0', 80, 100, 800);" style="opacity: 1;">
</a>
</div>
<div id="title1_profile_videos_0" class="xsmallText grayText padB3">
<a href="https://www.youtube.com/watch?v=${data.id}" title="${data.title}">${data.title}</a>
</div>
<div id="title2_profile_videos_0" class="xsmallText grayText padB3">
<span style="color: #333">${data.time}</span>
</div>
</center>
</div>`;
},
ovideos: (data) => {
return `<div class="video-cell" style="width:32.6%">
<div class="video-entry">
<div class="v120WideEntry">
<div class="v120WrapperOuter">
<div class="v120WrapperInner">
<a id="video-url-${data.id}" href="https://www.youtube.com/watch?v=${data.id}&feature=channel_page" rel="nofollow">
<img title="${data.title}" src="${data.thumbnail}" class="vimg120" qlicon="${data.id}" alt="${data.title}">
</a>
<div id="quicklist-icon-${data.id}" class="addtoQL90">
<a id="add-to-quicklist-${data.id}" href="#" ql="${data.id}" title="Add Video to QuickList">
<button class="master-sprite QLIconImg" title="" onclick="clicked_add_icon(this, this.parentNode.getAttribute('ql'), 0, 'https://web.archive.org/web/20090609053526/http://i2.ytimg.com/vi/YZsMgrxGaMA/default.jpg', 'Michael Buckley\'s Secrets to YouTube Success');return false;" onmouseover="mouseOverQuickAdd(this)" onmouseout="mouseOutQuickAdd(this)" onmousedown="urchinTracker('/Events/profile/QuickList+AddTo')"></button></a>
<div class="hid quicklist-inlist">
<a id="add-to-quicklist-${data.id}" href="#" ql="${data.id}" title="Add Video to QuickList"></a>
<a href="/web/20090609053526/http://www.youtube.com/watch_queue?all">Added</a>
</div>
</div>
<div class="video-time">
<span id="video-run-time-${data.id}">${data.time}</span>
</div>
</div>
</div>
</div>
<div class="video-main-content" id="video-main-content-${data.id}">
<div class="video-title">
<div class="video-short-title">
<span id="translated_short_prefix_${data.id}" style="font-size: 10px;" class="hid">[TRANSLATED]</span>
<a id="video-short-title-${data.id}" href="https://www.youtube.com/watch?v=${data.id}&feature=channel_page" title="${data.title}" rel="nofollow">${data.title}</a>
</div>
<div class="video-long-title">
<span id="translated_long_prefix_${data.id}" style="font-size: 10px;" class="hid">[TRANSLATED]</span>
<a id="video-long-title-${data.id}" href="https://www.youtube.com/watch?v=${data.id}&feature=channel_page" title="${data.title}" rel="nofollow">${data.title}</a>
</div>
</div>
<div id="video-description-${data.id}" class="video-description">
</div>
<div class="video-facets">
<span id="video-average-rating-${data.id}" class="video-rating-list video-rating-with-caps">
<div>
<button class="master-sprite ratingCapsVS-left" title=""></button>
<button class="master-sprite ratingCapsVS ratingCapsVS-5.0" title="5.0"></button>
<button class="master-sprite ratingCapsVS-right" title=""></button>
</div>
</span>
<span id="video-added-time-${data.id}" class="video-date-added">${data.upload}</span>
<span id="video-num-views-${data.id}" class="video-view-count">${data.views}</span>
<span id="video-average-rating-${data.id}" class="video-rating-grid video-rating-with-caps">
<div>
<button class="master-sprite ratingCapsVS-left" title=""></button>
<button class="master-sprite ratingCapsVS ratingCapsVS-5.0" title="5.0"></button>
<button class="master-sprite ratingCapsVS-right" title=""></button>
</div>
</span>
</div>
</div>
<div class="video-clear-list-left"></div>
</div>
</div>`;
}
}
}
};
var Playlist = {
Main: (data) => {
return `<div id="content">
<div id="branded-page-default-bg" class="ytg-base">
<div id="branded-page-body-container" class="ytg-base clearfix">
${document.cosmicCat.Template.Playlist.Header(data)}
${document.cosmicCat.Template.Playlist.Content(data)}
</div>
</div>
</div>`;
},
Header: (data) => {
var _a, _b, _c, _d, _e;
return `<div id="branded-page-header-container" class="ytg-wide">
<div id="branded-page-header" class="ytg-wide ytg-box">
<a class="profile-thumb" href="${data.header.owner.url}">
<span class="video-thumb ux-thumb yt-thumb-square-77">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.content[0].thumbnail}" alt="Thumbnail" width="77"><span class="vertical-align"></span>
</span>
</span>
</span>
</a>
<div class="ytg-box">
<div class="playlist-info">
<div class="header-right">
<div class="header-stats ytg-box">
<ul>
<li class="stat-entry first">
<span class="stat-value">${(_c = (_b = (_a = data.header.videos) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.split(" ")) === null || _c === void 0 ? void 0 : _c[0]}</span>
<span class="stat-name">videos</span>
</li>
<li class="stat-entry">
<span class="stat-value">${data.header.views}</span>
<span class="stat-name">views</span>
</li>
</ul>
</div>
</div>
<div class="playlist-reference">
<h1 title="${data.header.title}">${data.header.title}</h1>
${((_d = data.creatorInfo) === null || _d === void 0 ? void 0 : _d.id) ? `
<p class="channel-author-attribution">
${localizeString("playlists.header.channelAuthor", (_e = data.header) === null || _e === void 0 ? void 0 : _e.owner)}
</p>
` : ""}
</div>
<span id="play-all-button">
<a class="yt-playall-link yt-playall-link-dark yt-uix-sessionlink" href="https://www.youtube.com/watch?v=${data.content[0].id}&list=${data.header.id}" data-sessionlink="el">
<img class="small-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">Play all
</a>
</span>
</div>
</div>
</div>
</div>`;
},
Content: (data) => {
return `<div id="branded-page-body">
<div id="playlist-pane-container">
${document.cosmicCat.Template.Playlist.primaryPane.Main(data)}
${document.cosmicCat.Template.Playlist.secondaryPane.Main(data)}
</div>
</div>`;
},
primaryPane: {
Main: (data) => {
return `<div class="primary-pane">
<div class="playlist-landing ypc-list-container">
<div id="playlist-actions">
<div id="playlist-action-buttons">
<div id="playlist-likes-container">
<div class="playlist-sparkbars">
<div class="playlist-sparkbar-likes" style="width: 0%"></div>
<div class="playlist-sparkbar-dislikes" style="width: 0%"></div>
</div>
<span class="playlist-likes-dislikes">
<span class="likes">0</span> likes, <span class="dislikes">0</span> dislikes
</span>
</div>
${document.cosmicCat.Template.Buttons.LikeDis(data)}
<button type="button" class="playlist-share yt-uix-button yt-uix-button-default yt-uix-tooltip" onclick=";return false;" title="Share or embed this playlist" data-button-toggle="true" data-button-action="yt.www.playlist.share" role="button"><span class="yt-uix-button-content">Share </span></button>
<img src="//s.ytimg.com/yts/img/playlist/playlist-hangout-icon-vflZSwp9g.png" alt="Google Hangout" class="playlist-hangout-button" title="Watch with your friends.">
</div>
<div id="playlist-share-container" class="playlist-share-area hid">
</div>
<div id="playlist-share-loading" class="playlist-share-area hid">${localizeString("global.loading.main")}</div>
<div id="playlist-likes-signin-container" class="playlist-share-area hid">
<div class="yt-alert yt-alert-naked yt-alert-warn">
<div class="yt-alert-icon">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</div>
<div class="yt-alert-content" role="alert">
<span class="yt-alert-vertical-trick"></span>
<div class="yt-alert-message">
<strong>
<a href="${document.cosmicCat.data.loginUrl}">Sign in</a> or <a href="https://www.youtube.com/signup">sign up</a> now!
</strong>
</div>
</div>
</div>
</div>
</div>
<ol>
</ol>
</div>
</div>`;
},
listItem: {
video: (data, id, i) => {
var _a;
return `<li class="playlist-video-item odd annotated">
<div class="yt-uix-tile playlist-video-item-base-content">
<span class="video-index">${i}</span>
<div class="thumb-container">
<div class="ux-thumb-wrap">
<span class="video-thumb ux-thumb yt-thumb-default-124">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="Thumbnail" data-thumb="${data.thumbnail}" data-group-key="thumb-group-27" width="124"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${data.time}</span>
${document.cosmicCat.Template.Buttons.addTo(data.id)}
</div>
</div>
<div class="video-info">
<div class="video-buttons">
</div>
<div class="video-overview">
<h3 class="video-title-container">
<a href="https://www.youtube.com/watch?v=${data.id}&list=${id}&index=${i}&feature=plpp_video" class="yt-uix-tile-link">
<span class="title video-title yt-uix-tooltip" title="${data.title}" dir="ltr">${data.title}</span>
</a>
</h3>
<p class="video-details">
<span class="video-owner">
${localizeString("playlists.body.primaryPane.items.video.by", (_a = data === null || data === void 0 ? void 0 : data.owner) === null || _a === void 0 ? void 0 : _a.name)}
</span>
<span class="video-view-count">${data.views}</span>
</p>
</div>
</div>
</div>
</li>`;
}
}
},
secondaryPane: {
Main: (data) => {
var _a, _b, _c;
return `<div class="secondary-pane">
<div class="channel-module">
<h2>${localizeString("playlists.body.secondaryPane.aboutSection.about", ((_a = data.header) === null || _a === void 0 ? void 0 : _a.name) || ((_b = data.header) === null || _b === void 0 ? void 0 : _b.title))}</h2>
<p>${data.header.description}</p>
</div>
<hr class="yt-horizontal-rule">
${((_c = data.creatorInfo) === null || _c === void 0 ? void 0 : _c.id) ? document.cosmicCat.Template.Playlist.secondaryPane.aboutSection(data) : ""}
</div>`;
},
aboutSection: (data) => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
return `<div class="channel-module">
<div class="playlist-creator-info">
<h2>${localizeString("playlists.body.secondaryPane.aboutSection.about", ((_a = data.creatorInfo) === null || _a === void 0 ? void 0 : _a.name) || ((_b = data.creatorInfo) === null || _b === void 0 ? void 0 : _b.title))}</h2>
<p>${(_d = (_c = data.creatorInfo) === null || _c === void 0 ? void 0 : _c.fields) === null || _d === void 0 ? void 0 : _d.description}</p>
<div class="creator-links">
<a href="https://www.youtube.com/channel/${data.creatorInfo.id}/playlists">${localizeString("playlists.body.secondaryPane.aboutSection.creatorLinks.playlists", (_e = data === null || data === void 0 ? void 0 : data.creatorInfo) === null || _e === void 0 ? void 0 : _e.name)}</a>
<a href="https://www.youtube.com/channel/${data.creatorInfo.id}/videos">${localizeString("playlists.body.secondaryPane.aboutSection.creatorLinks.videos")}</a>
</div>
<div class="creator-stats">
<p>${(_g = (_f = data.creatorInfo) === null || _f === void 0 ? void 0 : _f.fields) === null || _g === void 0 ? void 0 : _g.views} views</p>
<p>${(_h = data.creatorInfo) === null || _h === void 0 ? void 0 : _h.subs} subscribers</p>
</div>
<div class="enable-fancy-subscribe-button">
${document.cosmicCat.Template.Buttons.Subscribe((_j = data.creatorInfo) === null || _j === void 0 ? void 0 : _j.id)}
</span>
</div>
<div class="yt-horizontal-rule"><span class="first"></span><span class="second"></span><span class="third"></span></div>
</div>`;
}
}
};
var Search = {
Main: (searchpar) => {
var _a, _b, _c, _d, _e, _f, _g, _h;
return `<div id="content">
<div id="search-header" class="yt-uix-expander yt-uix-expander-collapsed">
<h2>Search results for <strong class="query"><span class="search-title-lego">${searchpar}</span></strong></h2>
<div class="filter-top">
<button type="button" class="filter-button yt-uix-expander-head yt-uix-button yt-uix-button-default" onclick=";return false;" data-button-toggle="true" data-button-menu-id="some-nonexistent-menu" data-button-action="" role="button">
<span class="yt-uix-button-content">Filters </span>
<img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
</button>
<ul class="filter-crumb-list"></ul>
<p class="num-results">About <strong>${ytInitialData.estimatedResults.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",")}</strong> results</p>
<br class="clear">
</div>
<div id="filter-dropdown" class="yt-uix-expander-body"></div>
<div class="yt-horizontal-rule"><span class="first"></span><span class="second"></span><span class="third"></span></div>
</div>
<div id="search-base-div">
<div id="search-main" class="ytg-4col new-snippets">
<div id="results-main-content">
<ol id="search-results" class="result-list context-data-container"></ol>
</div>
</div>
</div>
<div id="search-footer-box" class="searchFooterBox">
<div class="yt-uix-pager" role="navigation">
<a href="/web/20121031234035/http://www.youtube.com/results?page=1" class="yt-uix-button yt-uix-sessionlink yt-uix-pager-button yt-uix-button-toggled yt-uix-button-default" data-sessionlink="" data-page="1" aria-label="Go to page 1">
<span class="yt-uix-button-content">1</span>
</a>
<a class="yt-uix-button yt-uix-sessionlink yt-uix-pager-button yt-uix-button-default" id="next-btn" data-sessionlink="" onclick="document.cosmicCat.Search.next(this.getAttribute('data-token'), this.getAttribute('data-page'))" data-token="${(_h = (_g = (_f = (_e = (_d = (_c = (_b = (_a = ytInitialData.contents.twoColumnSearchResultsRenderer) === null || _a === void 0 ? void 0 : _a.primaryContents) === null || _b === void 0 ? void 0 : _b.sectionListRenderer) === null || _c === void 0 ? void 0 : _c.contents) === null || _d === void 0 ? void 0 : _d[1]) === null || _e === void 0 ? void 0 : _e.continuationItemRenderer) === null || _f === void 0 ? void 0 : _f.continuationEndpoint) === null || _g === void 0 ? void 0 : _g.continuationCommand) === null || _h === void 0 ? void 0 : _h.token}" data-page="2">
<span class="yt-uix-button-content">Next »</span>
</a>
</div>
</div>
</div>`;
},
dropdownFilter: {
Main: (a, b, temC) => {
return `<div class="filter-col">
<h4 class="filter-col-title">${a[b].searchFilterGroupRenderer.title.simpleText}</h4>
<ul>
${temC}
</ul>
</div>
`;
},
Con: (data, b, searchpar) => {
return `<li class="filter">
${data && `<a class="filter-text filter-content" title="Search for last hour" href="https://www.youtube.com/results?search_query=${searchpar}&sp=${data}">${b}</a>` || `<span class="filter-content filter-selected">${b}</span>`}
</li>`;
}
},
videoRender: (videoData) => {
var _a;
let badges = "";
for (let i = 0; i < videoData.badges.length; i++) {
badges += `<li><a class="yt-badge-std">${videoData.badges[i].metadataBadgeRenderer.label}</a></li>`;
}
badges = (videoData.badges.length > 0) ? '<ul class="single-line-lego-list">' + badges + "</ul>" : "";
return `<li class="yt-grid-box result-item-video context-data-item" data-context-item-title="${videoData.title}" data-context-item-type="video" data-context-item-time="${videoData.time}" data-context-item-user="${videoData}" data-context-item-id="${videoData.id}" data-context-item-views="${videoData.views}">
<div id="" class="yt-uix-tile yt-lockup-list yt-tile-default yt-grid-box">
<div class="yt-lockup-thumbnail">
<a href="https://www.youtube.com/watch?v=${videoData.id}" class="ux-thumb-wrap yt-uix-sessionlink yt-uix-contextlink contains-addto result-item-thumb">
<span class="video-thumb ux-thumb yt-thumb-default-185">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="//i3.ytimg.com/vi/${videoData.id}/mqdefault.jpg" alt="Thumbnail" width="185"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${videoData.time}</span>
${document.cosmicCat.Template.Buttons.addTo(videoData.id)}
</a>
</div>
<div class="yt-lockup-content">
<h3>
<a class="yt-uix-contextlink yt-uix-sessionlink yt-uix-tile-link result-item-translation-title" dir="ltr" title="${videoData.title}" href="https://www.youtube.com/watch?v=${videoData.id}">${videoData.title}</a>
</h3>
<p class="description" dir="ltr">${videoData.description}</p>
<div class="yt-lockup-meta">
${badges}
<p class="facets">
<span class="date-added">${videoData.upload}</span>
<span class="metadata-separator">•</span>
<span class="viewcount">${videoData.views}</span>
</p>
<p><span class="username-prepend">${localizeString("watch.by", (_a = videoData === null || videoData === void 0 ? void 0 : videoData.owner) === null || _a === void 0 ? void 0 : _a.name)}</span></p>
</div>
</div>
</div>
</li>`;
},
sidethumb: (data) => {
var _a, _b;
return `<span class="sidethumb">
<span class="video-thumb ux-thumb yt-thumb-default-43">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${(_a = data.thumbnails[0]) === null || _a === void 0 ? void 0 : _a.url}" alt="Thumbnail" data-thumb="${(_b = data.thumbnails[0]) === null || _b === void 0 ? void 0 : _b.url}" data-group-key="thumb-group-6" width="43"><span class="vertical-align"></span>
</span>
</span>
</span>
</span>`;
},
playlistRender: (data) => {
let sideThumbs = "";
for (let i = 0; i < data.sidethumbs.length; i++) {
sideThumbs += document.cosmicCat.Template.Search.sidethumb(data.sidethumbs[i]);
}
return `<li class="yt-grid-box playlist *sr context-data-item" data-context-item-title="${data.title}" data-context-item-count="${data.videos.text}" data-context-item-id="${data.id}" data-context-item-type="playlist" data-context-item-videos="["nyMkLwSyOVQ", "2_HXUhShhmY", "lLJf9qJHR3E"]">
<div id="" class="yt-uix-tile yt-lockup-list yt-tile-default yt-grid-box">
<div class="yt-lockup-thumbnail">
<a href="${data.url}" class="yt-pl-thumb-link yt-uix-contextlink yt-uix-sessionlink" data-sessionlink="">
<span class="yt-pl-thumb">
<span class="video-thumb ux-thumb yt-thumb-feed-185">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="Thumbnail" data-thumb=""${data.thumbnail}" data-group-key="thumb-group-6" width="185"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="sidebar sidebar-height-124">
<span class="video-count-wrapper">
<span class="video-count-block">
<span class="count-label">${data.videos.text.split(" ")[0]}</span>
<span class="text-label">videos</span>
</span>
</span>
<span class="side-thumbs">
${sideThumbs}
</span>
</span>
</span>
<span class="yt-pl-thumb-overlay">
<span class="yt-pl-thumb-overlay-content"><img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">Play all</span>
</span>
</span>
</a>
</div>
<div class="yt-lockup-content">
<h3 class="yt-lockup-ellipsize">
<a class="yt-uix-contextlink yt-uix-sessionlink yt-uix-tile-link result-item-translation-title" dir="ltr" title="${data.title}" data-sessionlink="" href="${data.url}">${data.title}</a>
</h3>
<div class="yt-lockup-meta">
<ul class="single-line-lego-list">
<li>
<a href="/web/20121022214036/https://www.youtube.com/results?search_query=playlist%2C+playlist&lclk=playlist/a" class="yt-badge-std">playlist</a>
</li>
</ul>
<p class="facets"><a href="/playlist?list=${data.id}" class="video-count">${data.videos.text}</a></p>
<p>
<span class="username-prepend">by <a href="${data.owner.url}" class="yt-uix-sessionlink yt-user-name" data-sessionlink="ved=CFgQwRs%3D&ei=CNyy4KHLlbMCFSXtRAodZHCYmg%3D%3D" dir="ltr">${data.owner.name}</a></span></p>
</div>
</div>
</div>
</li>`;
},
channelRender: (data) => {
console.debug(data);
return `<li class="yt-grid-box result-item-channel *sr">
<div id="" class="yt-uix-tile yt-lockup-list yt-tile-default yt-grid-box">
<div class="yt-lockup-thumbnail">
<a href="${data.url}" class="ux-thumb-wrap yt-uix-sessionlink result-item-thumb" data-sessionlink="">
<span class="video-thumb ux-thumb yt-thumb-square-104">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.avatar}" alt="Thumbnail" width="104"><span class="vertical-align"></span>
</span>
</span>
</span>
</a>
</div>
<div class="yt-lockup-content">
<h3 class="yt-lockup-ellipsize">
<a class="yt-uix-contextlink yt-uix-sessionlink yt-uix-tile-link result-item-translation-title" dir="ltr" title="${data.name}" data-sessionlink="" href="${data.url}?feature=results_main">${data.name}</a>
</h3>
<p class="description yt-lockup-ellipsize" dir="ltr">${data.fields.description}</p>
<div class="yt-lockup-meta">
<ul class="single-line-lego-list">
<li>
<a href="https://www.youtube.com/results?search_query=channel%2C+channel&lclk=channel/a" class="yt-badge-std">channel</a></li>
</ul>
<p class="facets">
<span class="video-count">${data.videos}</span>
<span class="metadata-separator">|</span>
<span class="subscriber-count">${data.subscriberCount}</span>
</p>
<p>
${localizeString("search.channels.by", data)}
</p>
</div>
</div>
</div>
</li>`;
}
};
var Masthead = {
Main: () => {
return `<div id="masthead" class="" dir="ltr">
<a id="logo-container" href="https://www.youtube.com/" title="YouTube home">
<img id="logo" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="YouTube home">
</a>
<div id="masthead-user-bar-container">
<div id="masthead-user-bar">
<div id="masthead-user">
</div>
</div>
</div>
<div id="masthead-search-bar-container">
<div id="masthead-search-bar">
<div id="masthead-nav">
<a href="https://www.youtube.com/feed/explore">${localizeString("global.browse")}</a>
<span class="masthead-link-separator">|</span>
<a href="https://www.youtube.com/feed/storefront?feature=mh">Movies</a>
<span class="masthead-link-separator">|</span>
<a href="https://youtube.com/upload">${localizeString("global.upload")}</a>
</div>
<form id="masthead-search" class="search-form consolidated-form" action="https://www.youtube.com/results" onsubmit="if (document.body.querySelector('#masthead-search-term').value == '') return false;">
<button class="search-btn-compontent search-button yt-uix-button yt-uix-button-default" onclick="if (document.querySelector('#masthead-search-term').value == '') return false; document.querySelector('#masthead-search').submit(); return false;;return true;" type="submit" id="search-btn" dir="ltr" tabindex="2" role="button">
<span class="yt-uix-button-content">${localizeString("global.search")}</span>
</button>
<div id="masthead-search-terms" class="masthead-search-terms-border" dir="ltr" style="border-color: rgb(192, 192, 192) rgb(217, 217, 217) rgb(217, 217, 217);">
<label>
<input id="masthead-search-term" onfocus="document.querySelector('#masthead-search').classList.add('focused');document.querySelector('#masthead-search-terms').setAttribute('style', 'border-color: rgb(77, 144, 254)')" onblur="document.querySelector('#masthead-search').classList.remove('focused');document.querySelector('#masthead-search-terms').setAttribute('style', 'border-color: rgb(192, 192, 192) rgb(217, 217, 217) rgb(217, 217, 217);')" autocomplete="off" class="search-term" name="search_query" value="" type="text" tabindex="1" title="${localizeString("global.search")}" dir="ltr" spellcheck="false" style="outline: currentcolor none medium;">
</label>
</div>
<input type="hidden" name="oq">
<input type="hidden" name="aq">
<input type="hidden" name="aqi">
<input type="hidden" name="aql">
<input type="hidden" name="gs_sm">
<input type="hidden" name="gs_upl">
</form>
</div>
</div>
</div>
<div id="alerts"></div>`;
},
User: {
loggedIn: () => {
return `<span id="masthead-gaia-user-expander" class="masthead-user-menu-expander masthead-expander">
<span id="masthead-gaia-user-wrapper" class="yt-rounded" tabindex="0">${document.cosmicCat.Storage.get("accountInfo").value.name}</span></span>
<span id="masthead-gaia-photo-expander" class="masthead-user-menu-expander masthead-expander">
<span id="masthead-gaia-photo-wrapper" class="yt-rounded">
<span id="masthead-gaia-user-image">
<span class="clip">
<span class="clip-center">
<img src="${document.cosmicCat.Storage.get("accountInfo").value.pfp}" alt="">
<span class="vertical-center"></span>
</span>
</span>
</span>
<span class="masthead-expander-arrow"></span>
</span>
</span>`;
},
loggedOut: () => {
return `<div id="masthead-user-display">
<span id="masthead-user-wrapper">
<button href="${document.cosmicCat.data.loginUrl}" type="button" id="masthead-user-button" onclick=";window.location.href=this.getAttribute('href');return false;" class="yt-uix-button yt-uix-button-text" role="button">
<span class="yt-uix-button-content">
<span id="masthead-user-image">
<span class="clip">
<span class="clip-center">
<img src="//s.ytimg.com/yts/img/silhouette48-vflLdu7sh.png" alt="">
<span class="vertical-center"></span>
</span>
</span>
</span>
<span class="masthead-user-username">${localizeString("buttons.signin")}</span>
</span>
</button>
</span>
</div>`;
}
},
Expander: () => {
return `<div id="masthead-expanded" class="hid">
<div id="masthead-expanded-container" class="with-sandbar">
<div id="masthead-expanded-menus-container">
<span id="masthead-expanded-menu-shade"></span>
<div id="masthead-expanded-google-menu">
<span class="masthead-expanded-menu-header">${localizeString("personal.googleaccount")}</span>
<div id="masthead-expanded-menu-google-container">
<img id="masthead-expanded-menu-gaia-photo" alt="" src="${document.cosmicCat.Storage.get("accountInfo").value.pfp}">
<div id="masthead-expanded-menu-account-info">
<p>${document.cosmicCat.Storage.get("accountInfo").value.name}</p>
<p id="masthead-expanded-menu-email">${document.cosmicCat.Storage.get("accountInfo").value.email}</p>
</div>
<div id="masthead-expanded-menu-google-column1">
<ul>
<li class="masthead-expanded-menu-item"><a href="https://profiles.google.com?authuser=0">${localizeString("personal.profile")}</a></li>
<li class="masthead-expanded-menu-item"><a href="https://plus.google.com/u/0/stream">Google+</a></li>
<li class="masthead-expanded-menu-item"><a href="https://plus.google.com/u/0/settings/privacy">${localizeString("personal.privacy")}</a></li>
</ul>
</div>
<div id="masthead-expanded-menu-google-column2">
<ul>
<li class="masthead-expanded-menu-item">
<a href="/cosmic_cat">${localizeString("personal.settings")}</a>
</li>
<li class="masthead-expanded-menu-item">
<a class="end" href="javascript:document.cosmicCat.Account.logout();">${localizeString("personal.signout")}</a>
</li>
<li class="masthead-expanded-menu-item">
<a href="/channel_switcher" onclick="yt.www.masthead.accountswitch.toggle(); return false;">${localizeString("personal.switchaccount")}</a>
</li>
</ul>
</div>
</div>
</div>
<div id="masthead-expanded-menu">
<span class="masthead-expanded-menu-header">YouTube</span>
<ul id="masthead-expanded-menu-list">
<li class="masthead-expanded-menu-item">
<a href="/profile?feature=mhee">${localizeString("personal.mychannel")}</a>
</li>
<li class="masthead-expanded-menu-item">
<a href="/my_videos?feature=mhee">${localizeString("personal.videomanager")}</a>
</li>
<li class="masthead-expanded-menu-item">
<a href="/?c=subscriptions" onclick="document.cosmicCat.load.home_category(document.querySelector('[data-feed-name=subscriptions]')); return false;">${localizeString("personal.subscriptions")}</a>
</li>
<li class="masthead-expanded-menu-item">
<a href="/account?feature=mhee">${localizeString("personal.youtubesettings")}</a>
</li>
</ul>
</div>
</div>
<div id="masthead-expanded-sandbar">
<div id="masthead-expanded-lists-container">
<div id="masthead-expanded-loading-message">${localizeString("global.loading.main")}</div>
</div>
</div>
<div class="clear"></div>
</div>
</div>`;
}
};
var Footer = () => {
return `<div id="footer-container">
<div id="footer">
<div class="yt-horizontal-rule">
<span class="first"></span>
<span class="second"></span>
<span class="third"></span>
</div>
<div id="footer-logo">
<a href="https://www.youtube.com/" title="YouTube home">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="YouTube home">
</a>
<span id="footer-divider"></span>
</div>
<div id="footer-main">
<ul id="footer-links-primary">
<li>
<a href="https://www.youtube.com/t/about_youtube">${localizeString("footer.about")}</a>
</li>
<li>
<a href="https://www.youtube.com/t/press">${localizeString("footer.press")}</a>
</li>
<li>
<a href="https://www.youtube.com/t/copyright_center">${localizeString("footer.copyright")}</a>
</li>
<li>
<a href="https://www.youtube.com/creators">${localizeString("footer.creators")}</a>
</li>
<li>
<a href="https://www.youtube.com/t/advertising_overview">${localizeString("footer.advertising")}</a>
</li>
<li>
<a href="https://www.youtube.com/dev">${localizeString("footer.dev")}</a>
</li>
</ul>
<ul id="footer-links-secondary">
<li>
<a href="https://www.youtube.com/t/terms">${localizeString("footer.terms")}</a>
</li>
<li>
<a href="https://www.google.com/intl/en/policies/privacy/">${localizeString("footer.privacy")}</a>
</li>
<li>
<a href="https://support.google.com/youtube/bin/request.py?contact_type=abuse&hl=en-US">${localizeString("footer.safety")}</a>
</li>
<li>
<a href="https://www.google.com/tools/feedback/intl/en/error.html" onclick="return yt.www.feedback.start(yt.getConfig('FEEDBACK_LOCALE_LANGUAGE'), yt.getConfig('FEEDBACK_LOCALE_EXTRAS'));" id="reportbug">${localizeString("footer.feedback")}</a>
</li>
<li>
<a href="https://www.youtube.com/testtube">${localizeString("footer.testtube")}</a>
</li>
</ul>
<ul class="pickers yt-uix-button-group" data-button-toggle-group="optional">
<li>Language: <button type="button" class="yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-toggle="true" data-picker-position="footer" data-button-menu-id="arrow-display" data-picker-key="language" data-button-action="yt.www.picker.load" role="button"><span class="yt-uix-button-content">English </span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></button></li>
<li>Location: <button type="button" class="yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-toggle="true" data-picker-position="footer" data-button-menu-id="arrow-display" data-picker-key="country" data-button-action="yt.www.picker.load" role="button"><span class="yt-uix-button-content">Worldwide </span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></button></li>
<li>Safety: <button type="button" class="yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-toggle="true" data-picker-position="footer" data-button-menu-id="arrow-display" data-picker-key="safetymode" data-button-action="yt.www.picker.load" role="button"><span class="yt-uix-button-content">Off </span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></button></li>
</ul>
<div id="yt-picker-language-footer" class="yt-picker" style="display: none">
<p class="yt-spinner">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="yt-spinner-img" alt="">${localizeString("global.loading.main")}
</p>
</div>
<div id="yt-picker-country-footer" class="yt-picker" style="display: none">
<p class="yt-spinner">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="yt-spinner-img" alt="">${localizeString("global.loading.main")}
</p>
</div>
<div id="yt-picker-safetymode-footer" class="yt-picker" style="display: none">
<p class="yt-spinner">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="yt-spinner-img" alt="">${localizeString("global.loading.main")}
</p>
</div>
</div>`;
};
var Homepage = {
Main: () => {
return `<div id="content">
<div class="guide-layout-container enable-fancy-subscribe-button">
<div class="guide-container">
<div id="guide-builder-promo"></div>
<div class="guide"></div>
</div>
<div class="guide-background"></div>
<div id="feed" style="width: 790px;">
<div id="feed-main-youtube" class="individual-feed">
<div class="feed-header hid no-metadata before-feed-content">
<div class="feed-header-thumb">
<img class="feed-header-icon youtube" alt="" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif">
</div>
<div class="feed-header-details">
<h2 class="feed-header-info">${localizeString("guide.fromyt")}</h2>
</div>
</div>
<div class="feed-container">
<div class="feed-page">
<ul class="context-data-container"></ul>
</div>
</div>
</div>
<div id="feed-error" class="individual-feed hid">
<p class="feed-message">We were unable to complete the request, please try again later.</p>
</div>
<div id="feed-loading-template" class="hid">
<div class="feed-message">
<p class="loading-spinner">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
${localizeString("global.loading.main")}
</p>
</div>
</div>
</div>
<div id="feed-background" style="width: 790px;"></div>
</div>
</div>`;
},
Guide: {
Builder: {
loggedOut: () => {
return `<h2>Sign in to customize your homepage</h2>
<div id="guide-builder-promo-buttons" class="signed-out">
<button href="${document.cosmicCat.data.loginUrl}" type="button" class="yt-uix-button yt-uix-button-dark" onclick=";window.location.href=this.getAttribute('href');return false;" role="button">
<span class="yt-uix-button-content">Sign In </span>
</button>
<button href="/signup?next=%2Fchannels%3Ffeature%3Dsignup" type="button" class="yt-uix-button yt-uix-button-primary" onclick=";window.location.href=this.getAttribute('href');return false;" role="button">
<span class="yt-uix-button-content">Create Account </span>
</button>`;
},
loggedIn: () => {
return `<div id="guide-builder-promo-buttons">
<button type="button" class="yt-uix-button yt-uix-button-primary">
<span class="thumb">
<img class="yt-uix-button-icon-add" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="yt-uix-button-content">${localizeString("global.browsechannels")}</span>
</button>`;
}
},
Personal: () => {
return `<div id="channel">
<span id="channel-thumb">
<a href="/profile" class="yt-user-photo">
<span class="video-thumb ux-thumb yt-thumb-square-77">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${document.cosmicCat.Storage.get("accountInfo").value.pfp}" alt="${document.cosmicCat.Storage.get("accountInfo").value.name}" width="77"><span class="vertical-align"></span>
</span>
</span>
</span>
</a>
</span>
<div id="personal-feeds">
<ul>
<li class="guide-item-container">
<a class="guide-item guide-item-action" href="/profile?feature=guide">${localizeString("personal.mychannel")}<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" class="see-more-arrow" alt=""></a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="uploads" data-feed-type="personal" title="Videos you have uploaded">${localizeString("personal.videos")}</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="likes" data-feed-type="personal" title="Videos you have liked">${localizeString("personal.likes")}</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="history" data-feed-type="personal" title="Videos you have watched">${localizeString("personal.history")}</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="watch_later" data-feed-type="personal" title="Videos you have added to your Watch Later list">${localizeString("personal.watchlater")}</a>
</li>
</ul>
</div>
</div>
<div class="guide-section yt-uix-expander first">
<h3 class="guide-item-container">
<a class="guide-item" data-feed-name="subscriptions" data-feed-url="/feed/subscriptions?flow=2" data-feed-display="Subscriptions" data-feed-icon="subscriptions">
<span class="thumb">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="" class="system-icon category">
</span><span class="display-name">${localizeString("personal.subscriptions")}</span>
</a>
</h3>
<ul id="guide-subscriptions"></ul>
</div>`;
},
Channel: (data) => {
return `<li class="guide-item-container">
<a class="guide-item" data-feed-name="${data.channelRenderer.title.simpleText}" href="/channel/${data.channelRenderer.channelId}">
<span class="thumb">
<img class="system-icon" src="${data.channelRenderer.thumbnail.thumbnails[0].url}" alt="">
</span><span class="display-name">${data.channelRenderer.title.simpleText}</span>
</a>
</li>`;
},
Categories: {
Main: () => {
return `<div class="guide-section yt-uix-expander">
<h3 class="guide-item-container selected-child">
<a class="guide-item selected" data-feed-name="youtube" data-feed-url="/" data-feed-display="${localizeString("guide.fromyt")}">
<span class="thumb">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="" class="system-icon category">
</span><span class="display-name">${localizeString("guide.fromyt")}</span>
</a>
</h3>
<ul class="cockie"></ul>
</div>`;
},
Channel: (data) => {
return `<li class="guide-item-container">
<a class="guide-item" data-feed-name="${data.class}" data-feed-url="${data.href}">
<span class="thumb">
<img class="system-icon system ${data.class}" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">${data.name}</span>
</a>
</li>`;
}
}
},
Feed: {
Main: (data) => {
return `<li>
<div class="feed-item-container first" data-channel-key="${data.owner.id}">
<div class="feed-author-bubble-container">
<a href="${data.owner.url}/featured" class="feed-author-bubble">
<span class="feed-item-author">
<span class="video-thumb ux-thumb yt-thumb-square-28">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.owner.icon}" alt="${data.owner.text}" data-thumb="${data.icon}" width="28"><span class="vertical-align"></span>
</span>
</span>
</span>
</span>
</a>
</div>
<div class="feed-item-main">
<div class="feed-item-header">
<span class="feed-item-actions-line">
${localizeString("home.feed.uploadedavideo", data === null || data === void 0 ? void 0 : data.owner)} <span class="feed-item-time">${data.upload}</span>
</span>
</div>
<div class="feed-item-content-wrapper clearfix context-data-item" data-context-item-actionverb="uploaded" data-context-item-title="Steam for Linux a Bad Idea? - This Week in Linux Gaming" data-context-item-type="video" data-context-item-time="5:21" data-context-item-user="nixiedoeslinux" data-context-item-id="7LVtbTurdCk" data-context-item-views="25,816 views" data-context-item-actionuser="nixiedoeslinux">
<div class="feed-item-thumb">
<a class="ux-thumb-wrap contains-addto yt-uix-contextlink yt-uix-sessionlink" href="/watch?v=${data.id}">
<span class="video-thumb ux-thumb yt-thumb-default-185">
<span class="yt-thumb-clip"><span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="Thumbnail" width="185"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${data.time}</span>
${document.cosmicCat.Template.Buttons.addTo(data.id)}
</a>
</div>
<div class="feed-item-content">
<h4>
<a class="feed-video-title title yt-uix-contextlink yt-uix-sessionlink" href="/watch?v=${data.id}">${data.title}</a>
</h4>
<div class="metadata">
<span class="view-count">${data.views}</span>
<div class="description">
<p>${data.description}</p>
</div>
</div>
</div>
</div>
</div>
<span class="feed-item-action-menu subscribed" data-external-id="PqyfOmT8QmomqIwGPT4hxRGvXqh6izrXz8s1TlSF8fg0h_MQ8Qjx10A==">
<button type="button" class="flip yt-uix-button yt-uix-button-feed-item-action-menu yt-uix-button-empty" onclick=";return false;" data-button-has-sibling-menu="True" role="button" aria-pressed="false" aria-expanded="false" aria-haspopup="true" aria-activedescendant=""><span class="yt-uix-button-icon-wrapper"><img class="yt-uix-button-icon yt-uix-button-icon-feed-item-action-menu" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span></span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""><ul class=" yt-uix-button-menu yt-uix-button-menu-feed-item-action-menu" role="menu" aria-haspopup="true" style="display: none;"><li role="menuitem" id="aria-id-69285446284"><span data-action="hide" class="dismiss-menu-choice yt-uix-button-menu-item" onclick=";return false;">Hide this activity</span></li><li role="menuitem" id="aria-id-71783894232"><span data-subscription-id="s-g9bXtaCSKRwzCmeFkvD912YfxX4CmZ5I-IkGd8HUI" data-action="uploads" class="dismiss-menu-choice uploads yt-uix-button-menu-item" onclick=";return false;">Only show uploads from nixiedoeslinux
</span></li><li role="menuitem" id="aria-id-62584392243"><span data-action="subscribe" class="dismiss-menu-choice subscribe yt-uix-button-menu-item" onclick=";return false;">Subscribe to nixiedoeslinux
</span></li><li role="menuitem" id="aria-id-68105254288"><span data-channel-key="UCBE-FO9JUOghSysV9gjTeHw" onclick=";return false;" data-action="unsubscribe" data-subscription-id="s-g9bXtaCSKRwzCmeFkvD912YfxX4CmZ5I-IkGd8HUI" class="dismiss-menu-choice unsubscribe yt-uix-button-menu-item">Unsubscribe from nixiedoeslinux
</span></li></ul></button>
</span>
</div>
<div class="feed-item-dismissal-notices"><div class="feed-item-dismissal feed-item-dismissal-hide hid">This item has been hidden</div><div class="feed-item-dismissal feed-item-dismissal-uploads hid">In the future you will only see uploads from <span class="feed-item-owner"><a href="/user/nixiedoeslinux?feature=g-u-u" class="yt-uix-sessionlink yt-user-name " data-sessionlink="feature=g-u-u" dir="ltr">nixiedoeslinux</a></span>
</div><div class="feed-item-dismissal feed-item-dismissal-all-activity hid">In the future you will see all activity from <span class="feed-item-owner"><a href="/user/nixiedoeslinux?feature=g-u-u" class="yt-uix-sessionlink yt-user-name " data-sessionlink="feature=g-u-u" dir="ltr">nixiedoeslinux</a></span>
</div><div class="feed-item-dismissal feed-item-dismissal-unsubscribe hid">You have been unsubscribed from <span class="feed-item-owner"><a href="/user/nixiedoeslinux?feature=g-u-u" class="yt-uix-sessionlink yt-user-name " data-sessionlink="feature=g-u-u" dir="ltr">nixiedoeslinux</a></span>
</div></div>
</li>`;
}
}
};
var Settings = {
Main: () => {
addHandler("click", "guide-item-container", document.cosmicCat.Actions.handleSettingsTab);
return `<div id="content">
<div class="guide-layout-container enable-fancy-subscribe-button">
<div class="guide-container" style="height: 400px">
<div class="guide" data-last-clicked-item="youtube">
<div class="guide-section yt-uix-expander">
<ul class="settings-menu-list">
<li class="guide-item-container selected-child">
<a class="guide-item selected" data-feed-name="general">
<span class="thumb">
<img class="system-icon system" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">General</span>
</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="home">
<span class="thumb">
<img class="system-icon system" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">Home</span>
</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="channel">
<span class="thumb">
<img class="system-icon system" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">Channel</span>
</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="player">
<span class="thumb">
<img class="system-icon system" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">Player</span>
</a>
</li>
<li class="guide-item-container">
<a class="guide-item" data-feed-name="credits">
<span class="thumb">
<img class="system-icon system" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="">
</span><span class="display-name">Credits</span>
</a>
</li>
</ul>
</div>
</div>
<div id="disclaimer">Cosmic Cat v${GM_info.script.version}
Made with ♥ by Thistle Café -
and its contributors.</div>
</div>
<div class="guide-background" style="top: 0"></div>
<div id="feed" style="width: 790px;">
${document.cosmicCat.Template.Settings.Feeds.General()}
${document.cosmicCat.Template.Settings.Feeds.Home()}
${document.cosmicCat.Template.Settings.Feeds.Channel()}
${document.cosmicCat.Template.Settings.Feeds.Player()}
${document.cosmicCat.Template.Settings.Feeds.Credits()}
</div>
<div id="feed-background" style="width: 790px;"></div>
</div>
</div>`;
},
Feeds: {
General: () => {
return `<div id="feed-main-general" class="individual-feed selected">
<div class="feed-container">
<div class="feed-page">
<ul class="array" style="user-select: none;">
<li>
<div class="feed-item-container">
<div class="feed-item-main">
<label title="Enable/disable dark theme">Dark theme: <input type="checkbox" ${document.cosmicCat.Storage.get("dark").value == "1" ? "checked" : ""} id="darkTheme" data-action="toggleDarkTheme" data-storage="dark" class="cosmic-cat-settings ios-switch" /><div class="switch"></div></label>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>`;
},
Home: () => {
let options = "";
for (let i = 0; i < document.cosmicCat.data.homeCategories.length; i++) {
options += `<option value="${document.cosmicCat.data.homeCategories[i]}">${localizeString("guide." + document.cosmicCat.data.homeCategories[i])}</option>`;
}
return `<div id="feed-main-home" class="individual-feed hid">
<div class="feed-container">
<div class="feed-page">
<ul class="array" style="user-select: none;">
<li>
<div class="feed-item-container">
<div class="feed-item-main">
Main feed: <select class="cosmic-cat-settings" id="mainFeed" data-action="setHomeMainFeed" data-storage="greeting_feed" title="Set default feed for home page">
${(document.cosmicCat.Account.isLoggedIn()) ? `<option value="subscriptions">${localizeString("personal.subscriptions")}</option>` : ""}
<option value="youtube">${localizeString("guide.fromyt")}</option>
${options}
</select>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>`;
},
Channel: () => {
return `<div id="feed-main-channel" class="individual-feed hid">
<div class="feed-container">
<div class="feed-page">
<ul class="array" style="user-select: none;">
<li>
<div class="feed-item-container">
<div class="feed-item-main">
Channel revision: <select class="cosmic-cat-settings" id="channelMode" data-action="toggleChannelMode" data-storage="channel_mode" title="Set channel layout">
<option value="3">3.0</option>
<option value="2">2.0</option>
<option value="1" disabled="">1.0</option>
</select>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>`;
},
Player: () => {
return `<div id="feed-main-player" class="individual-feed hid">
<div class="feed-container">
<div class="feed-page">
<ul class="array" style="user-select: none;">
<li>
<div class="feed-item-container">
<div class="feed-item-main">
<label title="Enable/disable iframe player">iFrame Player: <input type="checkbox" ${document.cosmicCat.Storage.get("iframe").value == "1" ? "checked" : ""} id="iframe" data-storage="iframe" class="cosmic-cat-settings ios-switch" /><div class="switch"></div></label>
</div>
</div>
</li>
</ul>
</div>
</div>
</div>`;
},
Credits: () => {
return `<div id="feed-main-credits" class="individual-feed hid">
<div class="feed-container">
<div class="feed-page">
<pre style="text-align: center;overflow-y: auto;">
<h1>Cosmic Cat v${GM_info.script.version}</h1>
<h3>==== Cosmic Cat ====</h3>
Lead Developer -
JT fluffy, Emiri Floarea
<h3>==== Contributors / Acknowledgements ====</h3>
Original Cosmic Cat Developer (Until October, 2023) -
Emiri Floarea
Components from Vorapis v3 & Vorapis v3 Player -
<a href="https://github.com/VORAPIS" target="_blank">Reprety</a>
Vorapis v3 Player 2012 Skin -
rlego
YabaiComponent & OpenUix -
<a href="https://github.com/YukisCoffee" target="_blank">Taniko Yamamoto</a>
Components from Rehike -
<a href="https://github.com/orgs/Rehike" target="_blank">The Rehike Maintainers</a>
Cosmic Cat Branding -
<a href="https://github.com/UnderscoreAngel" target="_blank">UnderscoreAngel</a>
<a href="https://github.com/travy-patty" target="_blank">travy-patty</a>
ReturnYouTubeDislike -
<a href="https://github.com/Anarios" target="_blank">Dmitrii Selivanov</a>
StackOverflow Code Solutions -
<a href="https://stackoverflow.com" target="_blank">StackOverflow</a>
<h3>==== Translators ====</h3>
<a href="https://github.com/VexorionReal" target="_blank">Vexorion Real (Polish)</a>
View the rest on Github: <a href="https://github.com/cosmic-cat-yt/cosmic-cat">cosmic-cat-yt/cosmic-cat</a>
All source code is available in the public domain under The Unlicense.
</pre>
</div>
</div>
</div>`;
}
},
Stylesheet: () => {
return `<style>
[transition] {
transition: background-color .3s ease;
}
#disclaimer {
text-align: center;
position: absolute;
white-space: pre-wrap;
height: 60px;
bottom: 0;
width: inherit;
}
input[type="checkbox"] {
position : absolute;
opacity : 0;
}
input[type="checkbox"].ios-switch + div {
display : inline-block;
vertical-align : middle;
width : 3em;
height : 1em;
border : rgba(0, 0, 0, 0.3) solid 1px;
border-radius : 999px;
margin : 0 0.5em;
background : white;
background-image : linear-gradient(rgba(0, 0, 0, 0.1), transparent), linear-gradient(90deg, hsl(210, 90%, 60%) 50%, transparent 50%);
background-size : 200% 100%;
background-position : 100% 0;
background-origin : border-box;
background-clip : border-box;
overflow : hidden;
transition-duration : 0.4s;
transition-property : padding, width, background-position, text-indent;
box-shadow : 0 0.1em 0.1em rgba(0, 0, 0, 0.2) inset, 0 0.45em 0 0.1em rgba(0, 0, 0, 0.05) inset;
font-size : 150%;
}
input[type="checkbox"].ios-switch:checked + div {
padding-left : 2em;
width : 1em;
background-position : 0 0;
}
input[type="checkbox"].ios-switch + div:before {
content : 'On';
float : left;
width : 1.65em;
height : 1.65em;
margin : -0.1em;
border : rgba(0, 0, 0, 0.35) solid 1px;
border-radius : inherit;
background : white;
background-image : linear-gradient(rgba(0, 0, 0, 0.2), transparent);
box-shadow : 0 0.1em 0.1em 0.1em hsla(0, 0%, 100%, 0.8) inset, 0 0 0.5em rgba(0, 0, 0, 0.3);
color : white;
text-shadow : 0 -1px 1px rgba(0, 0, 0, 0.3);
text-indent : -2.5em;
}
input[type="checkbox"].ios-switch:active + div:before {
background-color : #eee;
}
input[type="checkbox"].ios-switch:focus + div {
box-shadow : 0 0.1em 0.1em rgba(0, 0, 0, 0.2) inset, 0 0.45em 0 0.1em rgba(0, 0, 0, 0.05) inset, 0 0 0.4em 1px rgba(255, 0, 0, 0.5);
}
input[type="checkbox"].ios-switch + div:before, input[type="checkbox"].ios-switch + div:after {
font : bold 60%/1.9 sans-serif;
text-transform : uppercase;
}
input[type="checkbox"].ios-switch + div:after {
content : 'Off';
float : left;
text-indent : 0.5em;
color : rgba(0, 0, 0, 0.45);
text-shadow : none;
}
</style>`;
}
};
var Buttons = {
Subscribe: (data) => {
const l = {
watch: () => {
return `<div class="yt-subscription-button-hovercard yt-uix-hovercard" data-card-class="watch-subscription-card">
<span class="yt-uix-button-context-light yt-uix-button-subscription-container">
<button onclick=";return false;" type="button" class="yt-subscription-button yt-uix-button yt-uix-button-subscription yt-uix-tooltip yt-subscription-button-js-default end ${document.cosmicCat.Channels.checkIfSubscribed() ? "subscribed hover-enabled" : ""}" data-enable-hovercard="true" data-subscription-value="${data}" data-subscription-feature="${document.cosmicCat.Utils.currentPage()}" data-subscription-type="" data-sessionlink="" data-subscription-initialized="true" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-subscribe" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span><span class="yt-uix-button-content">
<span class="subscribe-label">${localizeString("buttons.subscribe.subscribe")}</span>
<span class="subscribed-label">${localizeString("buttons.subscribe.subscribed")}</span>
<span class="unsubscribe-label">${localizeString("buttons.subscribe.unsubscribe")}</span>
</span>
</button>
<span class="yt-subscription-button-disabled-mask"></span>
</span>
</div>`;
},
channels: () => {
return `<div class="yt-subscription-button-hovercard yt-uix-hovercard">
<span class="yt-uix-button-context-light yt-uix-button-subscription-container">
<button onclick=";return false;" title="" type="button" class="yt-subscription-button subscription-button-with-recommended-channels yt-uix-button yt-uix-button-subscription yt-uix-tooltip ${document.cosmicCat.Channels.checkIfSubscribed() ? "subscribed hover-enabled" : ""}" data-enable-hovercard="true" data-subscription-value="${data}" data-force-position="" data-position="" data-subscription-feature="${document.cosmicCat.Utils.currentPage()}" data-subscription-type="" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-subscribe" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span><span class="yt-uix-button-content">
<span class="subscribe-label">${localizeString("buttons.subscribe.subscribe")}</span>
<span class="subscribed-label">${localizeString("buttons.subscribe.subscribed")}</span>
<span class="unsubscribe-label">${localizeString("buttons.subscribe.unsubscribe")}</span>
</span>
</button>
<span class="yt-subscription-button-disabled-mask"></span>
</span>
</div>`;
},
channels2: () => {
return `<span class="subscription-container" data-subscription-expandable-id="subscription-button-module-menu" data-subscription-channels-container="subscription-recommended-channels" data-subscription-value="${data}" data-subscription-menu-type="expander" data-subscription-xsrf="" data-subscription-feature="channel" data-subscription-type="user">
<button type="button" class="subscribe-button yt-uix-button yt-uix-tooltip ${document.cosmicCat.Channels.checkIfSubscribed() ? "yt-subscription-button-green" : "yt-uix-button-urgent"}" onclick=";return false;" title="${document.cosmicCat.Channels.checkIfSubscribed() ? localizeString("tooltip.channels2.subscribe.subscribed") : localizeString("tooltip.channels2.subscribe.subscribe")}" data-loaded="true" data-button-action="yt.www.subscriptions.button.toggleMenu" role="button" data-tooltip-text="${document.cosmicCat.Channels.checkIfSubscribed() ? localizeString("tooltip.channels2.subscribe.subscribed") : localizeString("tooltip.channels2.subscribe.subscribe")}">
<span class="yt-uix-button-content">${document.cosmicCat.Channels.checkIfSubscribed() ? localizeString("buttons.subscribe.subscribed") : localizeString("buttons.subscribe.subscribe")}</span>
</button>
<span class="subscription-subscribed-container hid">
<span class="subscription-options-button subscription-expander yt-uix-expander yt-uix-expander-collapsed" data-expander-action="yt.www.subscriptions.button.toggleMenu">
<span class="yt-uix-expander-head yt-rounded">
<button class="yt-uix-expander-arrow" onclick="return false;"></button>
<span class="yt-alert yt-alert-success yt-alert-small yt-alert-naked yt-rounded">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon" alt="Alert icon"><span class="yt-alert-content">Subscribed</span>
</span>
</span>
</span>
</span>
</span>`;
},
playlist: () => {
return `<button onclick=";return false;" title="" type="button" class="yt-subscription-button yt-subscription-button-js-default yt-uix-button yt-uix-button-subscription yt-uix-tooltip ${document.cosmicCat.Channels.checkIfSubscribed() ? "subscribed hover-enabled" : ""}" data-subscription-feature="${document.cosmicCat.Utils.currentPage()}" data-sessionlink="" data-subscription-value="${data}" data-subscription-type="" role="button" data-subscription-initialized="true">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-subscribe" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span><span class="yt-uix-button-content">
<span class="subscribe-label">${localizeString("buttons.subscribe.subscribe")}</span>
<span class="subscribed-label">${localizeString("buttons.subscribe.subscribed")}</span>
<span class="unsubscribe-label">${localizeString("buttons.subscribe.unsubscribe")}</span>
</span>
</button>`;
}
};
const l_signedout = `<button disabled="True" onclick=";return false;" title="No need to subscribe to yourself!" type="button" class="yt-subscription-button end yt-uix-button yt-uix-button-default yt-uix-tooltip" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.subscribe.subscribe")}</span>
</button>`;
return `${((document.cosmicCat.Channels.isOwner(data)) || document.cosmicCat.watch.isOwner()) ? l_signedout : l[document.cosmicCat.Utils.currentPage()]()}`;
},
LikeDis: (data) => {
return `<span id="watch-like-unlike" class="yt-uix-button-group">
<button onclick=";return false;" title="${localizeString("tooltip.watch.ilikethis")}" type="button" class="start yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip ${(document.cosmicCat.watch.isVideoLiked() ? "liked" : "")}" id="watch-like" data-button-toggle="true" data-button-action="yt.www.watch.actions.like" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-like" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="${localizeString("buttons.watch.ilikethis")}"><span class="yt-valign-trick"></span>
</span><span class="yt-uix-button-content">${localizeString("buttons.watch.like")}</span>
</button><button onclick=";return false;" title="${localizeString("tooltip.watch.idislikethis")}" type="button" class="end yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty ${(document.cosmicCat.watch.isVideoDisliked() ? "unliked" : "")}" id="watch-unlike" data-button-toggle="true" data-button-action="yt.www.watch.actions.unlike" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-unlike" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="${localizeString("tooltip.watch.idislikethis")}"><span class="yt-valign-trick"></span>
</span>
</button>
</span>`;
},
addTo: (data) => {
return `<button onclick=";return false;" title="Watch Later" type="button" class="addto-button video-actions addto-watch-later-button-sign-in yt-uix-button yt-uix-button-default yt-uix-button-short yt-uix-tooltip" data-button-menu-id="shared-addto-watch-later-login" data-video-ids="${data}" role="button" data-tooltip-text="Watch Later">
<span class="yt-uix-button-content">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Watch Later">
</span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
</button>`;
},
watchMoreRelated: (data) => {
return `<button type="button" id="watch-more-related-button" onclick=";return false;" class=" yt-uix-button yt-uix-button-default" data-button-action="yt.www.watch.watch5.handleLoadMoreRelated" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.suggestions.loadmoresuggestions")}</span>
</button>`;
}
};
var Watch = {
Content: {
playlistBar: {
Main: (data) => {
return `<div id="playlist-bar" class="active autoplay-on shuffle-off max" data-list-id="${data.id}" data-list-type="PL" data-index-offset="0" data-video-ids="" data-list-length="47" data-masked="True" data-video-url="/watch?v=&feature=BFa&list=${data.id}">
${document.cosmicCat.Template.Watch.Content.playlistBar.barBar(data)}
${document.cosmicCat.Template.Watch.Content.playlistBar.barTray.Main(data)}
</div>`;
},
aMain: () => {
return `<div id="playlist-bar" class="active autoplay-on shuffle-off max" data-list-id="2D5ACE7F76092751" data-list-type="PL" data-index-offset="0" data-video-ids="" data-list-length="47" data-masked="True" data-video-url="/watch?v=&feature=BFa&list=PL2D5ACE7F76092751">
<iframe id="playlist-bar-mask" src="javascript:""" allow="autoplay 'self'; fullscreen 'self'" data-ruffle-polyfilled="" frameborder="0"></iframe>
<div id="playlist-bar-bar-container">
<div id="playlist-bar-bar">
<div class="yt-alert yt-alert-naked yt-alert-success hid" id="playlist-bar-notifications">
<div class="yt-alert-icon">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</div>
<div class="yt-alert-content" role="alert"></div>
</div>
<span id="playlist-bar-info">
<span class="playlist-bar-active playlist-bar-group">
<button onclick=";return false;" title="Previous video" type="button" id="playlist-bar-prev-button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-prev" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Previous video"><span class="yt-valign-trick"></span>
</span>
</button>
<span class="playlist-bar-count">
<span class="playing-index">18</span> / <span class="item-count">47</span>
</span>
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-next-button" role="button" data-tooltip-text="Next video">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-next" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="playlist-bar-active playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button-toggled yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-autoplay-button" data-button-toggle="true" role="button" data-tooltip-text="Turn autoplay off"><span class="yt-uix-button-icon-wrapper"><img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-autoplay" src="//web.archive.org/web/20120805130558im_/https://s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span></span></button><button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-shuffle-button" data-button-toggle="true" role="button" data-tooltip-text="Turn shuffle on"><span class="yt-uix-button-icon-wrapper"><img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-shuffle" src="//web.archive.org/web/20120805130558im_/https://s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span></span></button></span><span class="playlist-bar-passive playlist-bar-group"><button onclick=";return false;" title="Play videos" type="button" id="playlist-bar-play-button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" role="button"><span class="yt-uix-button-icon-wrapper"><img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-play" src="//web.archive.org/web/20120805130558im_/https://s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Play videos"><span class="yt-valign-trick"></span></span></button><span class="playlist-bar-count"><span class="item-count">47</span></span></span><span id="playlist-bar-title" class="yt-uix-button-group"><button href="/web/20120805130558mp_/https://www.youtube.com/playlist?list=PL2D5ACE7F76092751" onclick=";window.location.href=this.getAttribute('href');return false;" title="More information about this playlist" type="button" class="yt-uix-tooltip yt-uix-tooltip-masked start playlist-title yt-uix-button yt-uix-button-default yt-uix-tooltip" role="button"><span class="yt-uix-button-content">Official 10 hour playlist </span></button><button href="/web/20120805130558mp_/https://www.youtube.com/user/TehN1ppe?feature=BF" type="button" class="yt-uix-tooltip yt-uix-tooltip-masked end yt-uix-button yt-uix-button-default" onclick=";window.location.href=this.getAttribute('href');return false;" role="button"><span class="yt-uix-button-content"> <span class="video-thumb ux-thumb yt-thumb-square-23 "><span class="yt-thumb-clip"><span class="yt-thumb-clip-inner"><img src="https://web.archive.org/web/20120805130558im_/https://i1.ytimg.com/i/xHoFjiQvDUvFXJTpXzKYQw/1.jpg?v=c0308b" alt="Thumbnail" width="23"><span class="vertical-align"></span></span></span></span>
<span class="yt-user-name" dir="ltr">TehN1ppe</span>
</span>
</button>
</span>
</span>
<a id="playlist-bar-lists-back" href="#">Return to active list</a>
<span id="playlist-bar-controls">
<span class="playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-text yt-uix-button-empty" onclick=";return false;" id="playlist-bar-toggle-button" role="button" data-tooltip-text="Hide playlist">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-toggle" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button-reverse flip yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-menu-id="playlist-bar-options-menu" data-button-has-sibling-menu="true" role="button"><span class="yt-uix-button-content">Options </span><img class="yt-uix-button-arrow" src="//web.archive.org/web/20120805130558im_/https://s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""></button></span></span> </div>
</div>
<div id="playlist-bar-tray-container">
<div id="playlist-bar-tray" class="yt-uix-slider yt-uix-slider-fluid" data-slider-offset="-4284">
<button class="yt-uix-button playlist-bar-tray-button yt-uix-button-default yt-uix-slider-prev" onclick="return false;"><img class="yt-uix-slider-prev-arrow" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Previous video"></button>
<button class="yt-uix-button playlist-bar-tray-button yt-uix-button-default yt-uix-slider-next" onclick="return false;"><img class="yt-uix-slider-next-arrow" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Next video"></button>
<div class="yt-uix-slider-body">
<div id="playlist-bar-tray-content" class="yt-uix-slider-slide" style="left: -4284px;">
<ol class="video-list">
<li class="playlist-bar-item yt-uix-slider-slide-unit loading" data-video-id="8ZcmTl_1ER8">
<a href="https://www.youtube.com/watch?v=8ZcmTl_1ER8&feature=BFa&list=PL2D5ACE7F76092751" title="" class="yt-uix-sessionlink" data-sessionlink="ei=CLKl0-DG0LECFRGNfAodf1H5ZA%3D%3D&feature=BFa">
<span class="video-thumb ux-thumb yt-thumb-default-106">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="" data-thumb-manual="true" data-thumb="//i4.ytimg.com/vi/8ZcmTl_1ER8/default.jpg" width="106"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="screen"></span>
<span class="count"><strong>1</strong></span><span class="play"><img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"></span><span class="yt-uix-button yt-uix-button-default delete"><img class="yt-uix-button-icon-playlist-bar-delete" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Delete"></span><span class="now-playing">Now playing</span><span dir="ltr" class="title"><span> <span class="uploader">by </span>
</span>
</span>
<span class="dragger"></span>
</a>
</li>
</ol>
<ol id="playlist-bar-help">
<li class="empty playlist-bar-help-message">Your queue is empty. Add videos to your queue using this button: <img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="addto-button-help"><br> or <a href="https://web.archive.org/web/20120805130558/https://accounts.google.com/ServiceLogin?uilel=3&service=youtube&passive=true&continue=https%3A%2F%2Fwww.youtube.com%2Fsignin%3Faction_handle_signin%3Dtrue%26feature%3Dplaylist%26nomobiletemp%3D1%26hl%3Den_US%26next%3D%252Fwatch%253Fv%253DJikPgxdmpJY%2526playnext%253D1%2526list%253DPL2D5ACE7F76092751%2526feature%253Dresults_main&hl=en_US&ltmpl=sso">sign in</a> to load a different list.</li>
</ol>
</div>
<div class="yt-uix-slider-shade-left"></div>
<div class="yt-uix-slider-shade-right"></div>
</div>
</div>
<div id="playlist-bar-save"></div>
<div id="playlist-bar-lists" class="dark-lolz"></div>
<div id="playlist-bar-loading">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Loading..."><span id="playlist-bar-loading-message">Loading...</span><span id="playlist-bar-saving-message" class="hid">Saving...</span>
</div>
<div id="playlist-bar-template" style="display: none;" data-video-thumb-url="//i4.ytimg.com/vi/__video_encrypted_id__/default.jpg">
<!--<li class="playlist-bar-item yt-uix-slider-slide-unit __classes__" data-video-id="__video_encrypted_id__">
<a href="__video_url__" title="__video_title__" class="yt-uix-sessionlink" data-sessionlink="ei=CLKl0-DG0LECFRGNfAodf1H5ZA%3D%3D&feature=BFa">
<span class="video-thumb ux-thumb yt-thumb-default-106 ">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="https://s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="__video_title__" data-thumb-manual="true" data-thumb="__video_thumb_url__" width="106" ><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="screen"></span>
<span class="count"><strong>__list_position__</strong></span><span class="play"><img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"></span><span class="yt-uix-button yt-uix-button-default delete"><img class="yt-uix-button-icon-playlist-bar-delete" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Delete"></span><span class="now-playing">Now playing</span><span dir="ltr" class="title"><span>__video_title__ <span class="uploader">by __video_display_name__</span>
</span>
</span>
<span class="dragger"></span>
</a>
</li>-->
</div>
<div id="playlist-bar-next-up-template" style="display: none;">
<!--<div class="playlist-bar-next-thumb">
<span class="video-thumb ux-thumb yt-thumb-default-74">
<span class="yt-thumb-clip"><span class="yt-thumb-clip-inner">
<img src="//i4.ytimg.com/vi/__video_encrypted_id__/default.jpg" alt="Thumbnail" width="74"><span class="vertical-align"></span>
</span>
</span>
</span>
</div>-->
</div>
</div>
<div id="playlist-bar-options-menu" class="hid active">
<ul class="playlist-bar-passive-menu">
<li>
<span class="yt-uix-button-menu-item" data-action="show-active">Return to: Official 10 hour playlist</span>
</li>
</ul>
<div id="playlist-bar-extras-menu">
<ul>
<li>
<span class="yt-uix-button-menu-item" onclick="window.location.href='/playlist?list=PL2D5ACE7F76092751'">More information about this playlist</span>
</li>
</ul>
</div>
<ul>
<li>
<span class="yt-uix-button-menu-item" onclick="window.location.href='//support.google.com/youtube/bin/answer.py?answer=146749&hl=en-US'">Learn more</span>
</li>
</ul>
</div>
</div>`;
},
barBar: (data) => {
return `<div id="playlist-bar-bar-container">
<div id="playlist-bar-bar">
<div class="yt-alert yt-alert-naked yt-alert-success hid" id="playlist-bar-notifications">
<div class="yt-alert-icon">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</div>
<div class="yt-alert-content" role="alert"></div>
</div>
<span id="playlist-bar-info">
<span class="playlist-bar-active playlist-bar-group">
<button onclick=";return false;" title="Previous video" type="button" id="playlist-bar-prev-button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-prev" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Previous video"><span class="yt-valign-trick"></span>
</span>
</button>
<span class="playlist-bar-count">
<span class="playing-index">${data.videos.runs[0].text}</span> / <span class="item-count">${data.videos.runs[2].text}</span>
</span>
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-next-button" role="button" data-tooltip-text="Next video">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-next" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="playlist-bar-active playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button-toggled yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-autoplay-button" data-button-toggle="true" role="button" data-tooltip-text="Turn autoplay off">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-autoplay" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" id="playlist-bar-shuffle-button" data-button-toggle="true" role="button" data-tooltip-text="Turn shuffle on">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-shuffle" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="playlist-bar-passive playlist-bar-group">
<button onclick=";return false;" title="Play videos" type="button" id="playlist-bar-play-button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-play" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Play videos"><span class="yt-valign-trick"></span>
</span>
</button>
<span class="playlist-bar-count">
<span class="item-count">47</span>
</span>
</span>
<span id="playlist-bar-title" class="yt-uix-button-group">
<button href="https://www.youtube.com/playlist?list=${data.id}" onclick=";window.location.href=this.getAttribute('href');return false;" title="More information about this playlist" type="button" class="yt-uix-tooltip yt-uix-tooltip-masked start playlist-title yt-uix-button yt-uix-button-default yt-uix-tooltip" role="button">
<span class="yt-uix-button-content">${data.title}</span>
</button><button href="${data.owner.url}" type="button" class="yt-uix-tooltip yt-uix-tooltip-masked end yt-uix-button yt-uix-button-default" onclick=";window.location.href=this.getAttribute('href');return false;" role="button">
<span class="yt-uix-button-content">
<span class="video-thumb ux-thumb yt-thumb-square-23">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="" alt="Thumbnail" width="23"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="yt-user-name" dir="ltr">${data.owner.name}</span>
</span>
</button>
</span>
</span>
<a id="playlist-bar-lists-back" href="#">Return to active list</a>
<span id="playlist-bar-controls">
<span class="playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button yt-uix-button-text yt-uix-button-empty" onclick=";return false;" id="playlist-bar-toggle-button" role="button" data-tooltip-text="Hide playlist">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-playlist-bar-toggle" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""><span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="playlist-bar-group">
<button type="button" class="yt-uix-tooltip yt-uix-tooltip-masked yt-uix-button-reverse flip yt-uix-button yt-uix-button-text" onclick=";return false;" data-button-menu-id="playlist-bar-options-menu" data-button-has-sibling-menu="true" role="button"><span class="yt-uix-button-content">Options </span><img class="yt-uix-button-arrow" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt=""></button>
</span>
</span>
</div>
</div>`;
},
barTray: {
Main: () => {
return `<div id="playlist-bar-tray-container">
<div id="playlist-bar-tray" class="yt-uix-slider yt-uix-slider-fluid" data-slider-offset="-4284">
<button class="yt-uix-button playlist-bar-tray-button yt-uix-button-default yt-uix-slider-prev" onclick="return false;"><img class="yt-uix-slider-prev-arrow" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Previous video"></button>
<button class="yt-uix-button playlist-bar-tray-button yt-uix-button-default yt-uix-slider-next" onclick="return false;"><img class="yt-uix-slider-next-arrow" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Next video"></button>
${document.cosmicCat.Template.Watch.Content.playlistBar.barTray.Body()}
</div>
<div id="playlist-bar-save"></div>
<div id="playlist-bar-lists" class="dark-lolz"></div>
${document.cosmicCat.Template.Watch.Content.playlistBar.barTray.Loading()}
</div>`;
},
Body: () => {
return `<div class="yt-uix-slider-body">
${document.cosmicCat.Template.Watch.Content.playlistBar.barTray.trayContent.Content()}
<div class="yt-uix-slider-shade-left"></div>
<div class="yt-uix-slider-shade-right"></div>
</div>`;
},
Loading: () => {
return `<div id="playlist-bar-loading">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Loading..."><span id="playlist-bar-loading-message">Loading...</span><span id="playlist-bar-saving-message" class="hid">Saving...</span>
</div>`;
},
trayContent: {
Content: () => {
return `<div id="playlist-bar-tray-content" class="yt-uix-slider-slide" style="left: 0px;">
<ol class="video-list"></ol>
<ol id="playlist-bar-help">
<li class="empty playlist-bar-help-message">Your queue is empty. Add videos to your queue using this button: <img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="addto-button-help"><br> or <a href="">sign in</a> to load a different list.</li>
</ol>
</div>`;
},
video: (data, pl) => {
return `<li class="playlist-bar-item yt-uix-slider-slide-unit" data-video-id="${data.id}">
<a href="https://www.youtube.com/watch?v=${data.id}&feature=BFa&list=${pl.id}" title="" class="yt-uix-sessionlink" data-sessionlink="ei=CLKl0-DG0LECFRGNfAodf1H5ZA%3D%3D&feature=BFa">
<span class="video-thumb ux-thumb yt-thumb-default-106">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${data.thumbnail}" alt="" data-thumb-manual="true" data-thumb="${data.thumbnail}" width="106"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="screen"></span>
<span class="count"><strong>1</strong></span>
<span class="play"><img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif"></span>
<span class="yt-uix-button yt-uix-button-default delete">
<img class="yt-uix-button-icon-playlist-bar-delete" src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="Delete"></span>
<span class="now-playing">Now playing</span>
<span dir="ltr" class="title">${data.title}<span>
<span class="uploader">by ${data.owner.name}</span>
</span>
</span>
<span class="dragger"></span>
</a>
</li>`;
}
}
}
},
metadata: (videoData) => {
var _a, _b;
return `<link itemprop="url" href="http://www.youtube.com/watch?v=${videoData.primary.id}">
<meta itemprop="name" content="${videoData.primary.title}">
<meta itemprop="description" content="${document.cosmicCat.Utils.escapeHtml(videoData.secondary.description)}">
<meta itemprop="duration" content="PT0M18S">
<meta itemprop="unlisted" content="False">
<meta itemprop="paid" content="False">
<span itemprop="author" itemscope="" itemtype="http://schema.org/Person">
<link itemprop="url" href="${(_b = (_a = videoData.secondary) === null || _a === void 0 ? void 0 : _a.owner) === null || _b === void 0 ? void 0 : _b.url}">
</span>
<link itemprop="thumbnailUrl" href="${videoData.primary.thumbnail}">
<span itemprop="thumbnail" itemscope="" itemtype="http://schema.org/ImageObject">
<link itemprop="url" href="${videoData.primary.thumbnail}">
<meta itemprop="width" content="320">
<meta itemprop="height" content="180">
</span>
<link itemprop="embedURL" href="http://www.youtube.com/v/${videoData.primary.id}?version=3&autohide=1">
<meta itemprop="playerType" content="Flash">
<meta itemprop="width" content="480">
<meta itemprop="height" content="360">
<meta itemprop="isFamilyFriendly" content="True">`;
},
Main: (data) => {
return `<div id="content" class="">
<div id="watch-container" itemscope="" itemtype="https://schema.org/VideoObject">
${document.cosmicCat.Template.Watch.Content.metadata(data)}
${document.cosmicCat.Template.Watch.Content.Headline(data)}
${document.cosmicCat.Template.Watch.Content.videoCon()}
${document.cosmicCat.Template.Watch.Content.mainCon.Main(data)}
</div>
</div>
<style>#player {display:none}</style>`;
},
tag: (data, i) => {
return `<li><a href="https://www.youtube.com/results?search_query=${data.alternative.tags[i]}&search=tag">${data.alternative.tags[i]}</a></li>
`;
},
ownerContainer: (data) => {
return `<div id="watch-owner-container">
<div id="masthead-subnav" class="yt-nav yt-nav-dark">
<ul class="yt-nav-aside">
<li>
<a href="https://www.youtube.com/analytics#fi=v-${data.id}" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Analytics</span>
</a>
</li>
<li>
<a href="https://www.youtube.com/my_videos" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Video Manager</span>
</a>
</li>
</ul>
<ul>
<li>
<a href="https://studio.youtube.com/video/${data.id}/edit" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Edit</span>
</a>
</li>
<li>
<a href="https://studio.youtube.com/video/${data.id}/editor" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Enhancements</span>
</a>
</li>
<li>
<a href="https://studio.youtube.com/video/${data.id}/editor" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Audio</span>
</a>
</li>
<li>
<a href="https://studio.youtube.com/video/${data.id}/editor" class="yt-uix-button yt-uix-button-subnav yt-uix-sessionlink yt-uix-button-dark">
<span class="yt-uix-button-content">Annotations</span>
</a>
</li>
<li>
<button type="button" class=" yt-uix-button yt-uix-button-dark yt-uix-button-empty" onclick=";return false;" role="button" aria-pressed="false" aria-expanded="false" aria-haspopup="true" aria-activedescendant="">
<img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
<ul class=" yt-uix-button-menu yt-uix-button-menu-dark" role="menu" aria-haspopup="true" style="display: none;">
<li role="menuitem" id="aria-id-82239352096">
<span href="/my_videos_timedtext?video_id=${data.id}" class=" yt-uix-button-menu-item" onclick=";window.location.href=this.getAttribute('href');return false;">Captions</span>
</li>
<li role="menuitem" id="aria-id-93589831653">
<span href="/my_video_ad?v=${data.id}&utm_source=youtube&utm_campaign=yt_watch&utm_medium=permanent&utm_content=header_menu&utm_term=dropdown" class=" yt-uix-button-menu-item" onclick=";window.location.href=this.getAttribute('href');return false;">Promote</span>
</li>
</ul>
</button>
</li>
</ul>
</div>
</div>`;
},
Headline: (data) => {
var _a, _b, _c, _d, _e, _f;
return `<div id="watch-headline-container" class="">
${document.cosmicCat.watch.isOwner() ? document.cosmicCat.Template.Watch.Content.ownerContainer(data.alternative) : ""}
<div id="watch-headline" class="watch-headline">
<h1 id="watch-headline-title">
<span id="eow-title" class="" dir="ltr" title="${data.primary.title}">
${data.primary.title}
</span>
</h1>
<div id="watch-headline-user-info">
<span class="yt-uix-button-group">
<button href="${(_b = (_a = data.secondary) === null || _a === void 0 ? void 0 : _a.owner) === null || _b === void 0 ? void 0 : _b.url}/featured?feature=watch" type="button" class="start yt-uix-button yt-uix-button-default" onclick=";window.location.href=this.getAttribute('href');return false;" role="button">
<span class="yt-uix-button-content">${(_d = (_c = data.secondary) === null || _c === void 0 ? void 0 : _c.owner) === null || _d === void 0 ? void 0 : _d.name}</span>
</button>${document.cosmicCat.Template.Buttons.Subscribe((_f = (_e = data.alternative) === null || _e === void 0 ? void 0 : _e.owner) === null || _f === void 0 ? void 0 : _f.id)}
</span>
</div>
<div id="watch-more-from-user" class="collapsed">
<div id="watch-channel-discoverbox" class="yt-rounded">
<span id="watch-channel-loading">${localizeString("global.loading.main")}</span>
</div>
</div>
</div>
</div>`;
},
videoCon: () => {
return `<div id="watch-video-container">
<div id="watch-video">
<div id="watch-player" class="flash-player player-root wm-videoplayer">
</div>
</div>
</div>`;
},
mainCon: {
Main: (data) => {
return `<div id="watch-main-container" class="">
<div id="watch-main">
${document.cosmicCat.Template.Watch.Content.mainCon.panel.Main(data)}
${document.cosmicCat.Template.Watch.Content.mainCon.sideBar.Main(data)}
<div class="clear"></div>
</div>
<div style="visibility: hidden; height: 0px; padding: 0px; overflow: hidden;">
<div id="baseDiv"></div>
</div>
</div>
<style>
.yt-thumb-default-120 img {
width: 120px;
}
</style>`;
},
panel: {
Main: (data) => {
var _a, _b, _c;
return `<div id="watch-panel">
<div id="watch-actions">
<div id="watch-actions">
<div id="watch-actions-right">
<span class="watch-view-count">
<strong>${document.cosmicCat.Utils.parseNumber((_c = (_b = (_a = data.primary) === null || _a === void 0 ? void 0 : _a.views) === null || _b === void 0 ? void 0 : _b.split(" ")) === null || _c === void 0 ? void 0 : _c[0])}</strong>
</span>
<button onclick=";return false;" type="button" id="watch-insight-button" class="yt-uix-tooltip yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" role="button" title="Show video statistics">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-insight" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Show video statistics"><span class="yt-valign-trick"></span>
</span>
</button>
</div>
${document.cosmicCat.Template.Buttons.LikeDis(data)}
<button type="button" class="yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip" onclick=";return false;" title="${localizeString("tooltip.watch.addto")}" data-upsell="playlist" data-button-action="yt.www.watch.actions.addto" role="button">
<span class="yt-uix-button-content">
<span class="addto-label">${localizeString("buttons.watch.addto")}</span>
</span>
</button>
<button onclick=";return false;" title="${localizeString("tooltip.watch.share")}" class="yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip" id="watch-share" data-button-action="yt.www.watch.actions.share" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.watch.share")}</span>
</button>
<button onclick=";return false;" title="${localizeString("tooltip.watch.flag")}" type="button" class="yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" id="watch-flag" data-button-action="yt.www.watch.actions.flag" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-flag" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="${localizeString("tooltip.watch.flag")}"><span class="yt-valign-trick"></span>
</span>
</button>
<button onclick=";return false;" type="button" class="yt-uix-tooltip-reverse yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" id="watch-transcript" data-button-action="yt.www.watch.actions.transcript" role="button" title="${localizeString("tooltip.watch.transcript")}">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-transcript" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="${localizeString("tooltip.watch.transcript")}"><span class="yt-valign-trick"></span>
</span>
</button>
</div>
</div>
<div id="watch-actions-area-container" class="hid">
<div id="watch-actions-area" class="yt-rounded">
<div id="watch-actions-loading" class="watch-actions-panel hid">${localizeString("global.loading.main")}</div>
<div id="watch-actions-logged-out" class="watch-actions-panel hid">
<div class="yt-alert yt-alert-warn yt-alert-small yt-alert-naked yt-rounded">
<span class="yt-alert-icon">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</span>
<div class="yt-alert-content">
<strong>
<a href="https://accounts.google.com/ServiceLogin?service=youtube&uilel=3&passive=true&continue=https%3A%2F%2Fwww.youtube.com%2Fsignin%3Faction_handle_signin%3Dtrue%26app%3Ddesktop%26hl%3Den%26next%3Dhttps%253A%252F%252Fwww.youtube.com%252F&hl=en&ec=65620">Sign In</a> or <a href="https://www.youtube.com/signup">Sign Up</a> now!
</strong>
</div>
</div>
</div>
<div id="watch-actions-error" class="watch-actions-panel hid">
<div class="yt-alert yt-alert-error yt-alert-small yt-alert-naked yt-rounded">
<span class="yt-alert-icon">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</span>
<div id="watch-error-string" class="yt-alert-content"></div>
</div>
</div>
<div id="watch-actions-share" class="watch-actions-panel hid">
${document.cosmicCat.Template.Watch.Content.mainCon.panel.Share(data)}
</div>
<div id="watch-actions-Ajax" class="watch-actions-panel hid"></div>
<div class="close">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="close-button" onclick="document.cosmicCat.toggleElm('#watch-actions-area-container')">
</div>
</div>
</div>
<div id="watch-info">
<div id="watch-description" class="yt-uix-expander-collapsed yt-uix-expander">
<div id="watch-description-clip">
<p id="watch-uploader-info">${localizeString("watch.uploaderinfo", data)}</p>
<div id="watch-description-text">
<p id="eow-description">${data.secondary.description}</p>
</div>
<div id="watch-description-extras">
<h4>${localizeString("watch.watchInfo.category")}</h4>
<p id="eow-category"><a href="//www.youtube.com/featured">${data.primary.category}</a></p>
<h4 class="${(data.alternative.tags.length == 0 ? "hid" : "")}">${localizeString("watch.watchInfo.tags")}</h4>
<ul id="eow-tags" class="watch-info-tag-list ${(data.alternative.tags.length == 0 ? "hid" : "")}">
</ul>
<h4>${localizeString("watch.watchInfo.license")}</h4>
<p id="eow-reuse">Standard YouTube License</p>
</div>
</div>
<ul id="watch-description-extra-info">
<li>
<div class="video-extras-sparkbars" style="background-color:red">
<div class="video-extras-sparkbar-likes" style="width: 100%;"></div>
</div>
<span class="video-extras-likes-dislikes">
${localizeString("stats.likesdislikes")}
</span>
</li>
</ul>
<div class="yt-horizontal-rule">
<span class="first"></span>
<span class="second"></span>
<span class="third"></span>
</div>
<div id="watch-description-toggle" class="yt-uix-expander-head">
<div id="watch-description-expand" class="expand">
<button type="button" class="metadata-inline yt-uix-button yt-uix-button-text" onclick="return false;" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.watch.showmore")} <img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="${localizeString("buttons.watch.showmore")}"></span>
</button>
</div>
<div id="watch-description-collapse" class="collapse">
<button type="button" class="metadata-inline yt-uix-button yt-uix-button-text" onclick="return false;" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.watch.showless")} <img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="${localizeString("buttons.watch.showless")}"></span>
</button>
</div>
</div>
</div>
</div>
${document.cosmicCat.Template.Comments.Main(data)}`;
},
Share: (data) => {
console.log(data);
return `<div id="watch-actions-share-panel" class="" style="">
<div class="share-panel">
<div class="share-option-container ytg-box">
<div class="share-panel-buttons yt-uix-expander yt-uix-expander-collapsed">
<span class="share-panel-main-buttons">
<button type="button" class="share-panel-embed yt-uix-button yt-uix-button-default" onclick=";return false;" role="button">
<span class="yt-uix-button-content">Embed </span>
</button><button type="button" class="share-panel-email yt-uix-button yt-uix-button-default" onclick=";return false;" role="button">
<span class="yt-uix-button-content">Email </span>
</button>
</span>
</div>
<div class="share-panel-url-container">
<span class=" yt-uix-form-input-container yt-uix-form-input-text-container yt-uix-form-input-non-empty">
<input class="yt-uix-form-input-text share-panel-url" name="share_url" value="http://youtu.be/${data.alternative.id}" data-video-id="${data.alternative.id}">
</span>
<div class="share-panel-url-options yt-uix-expander yt-uix-expander-collapsed">
<div class="yt-uix-expander-head">
<a class="share-panel-show-url-options">
<span class="collapsed-message">Options<img class="arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></span>
<span class="expanded-message">Close<img class="arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></span>
</a>
</div>
<ul class="yt-uix-expander-body share-options">
<li>
<label>
<input class="share-panel-start-at" type="checkbox"> Start at:
</label>
<input type="text" value="0:00" class="yt-uix-form-input-text share-panel-start-at-time">
</li>
<li>
<label>
<input class="share-panel-long-url" type="checkbox"> Long link
</label>
</li>
</ul>
</div>
</div>
<div class="share-panel-services yt-uix-expander yt-uix-expander-collapsed clearfix">
<ul class="share-group ytg-box">
<li>
<button onclick="window.open("http:\/\/www.facebook.com\/dialog\/feed?app_id=87741124305\u0026link=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026display=popup\u0026redirect_uri=https%3A%2F%2Fwww.youtube.com%2Ffacebook_redirect", {'height': 306,'width': 650,'scrollbars': true});return false;" data-service-name="FACEBOOK" title="Share to Facebook" class="yt-uix-tooltip share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Facebook" class="share-service-icon share-service-icon-facebook">
<span>Facebook</span>
</button>
</li>
<li>
<button onclick="window.open("http:\/\/twitter.com\/intent\/tweet?url=http%3A%2F%2Fyoutu.be%2F${data.alternative.id}\u0026text=${encodeURIComponent(data.alternative.title)}%3A\u0026via=youtube\u0026related=Youtube%2CYouTubeTrends%2CYTCreators", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="TWITTER" title="Share to Twitter" class="yt-uix-tooltip share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Twitter" class="share-service-icon share-service-icon-twitter">
<span>Twitter</span>
</button>
</li>
<li>
<button onclick="window.open("https:\/\/plus.google.com\/share?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026source=yt\u0026hl=en", {'height': 620,'width': 620,'scrollbars': true});return false;" data-service-name="GOOGLEPLUS" title="Share to Google+" class="yt-uix-tooltip share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Google+" class="share-service-icon share-service-icon-googleplus">
<span>Google+</span>
</button>
</li>
</ul>
<div class="yt-uix-expander-head clearfix">
<a class="share-panel-show-more">
<span class="collapsed-message">More<img class="arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></span>
<span class="expanded-message">Less<img class="arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt=""></span>
</a>
</div>
<div class="yt-uix-expander-body share-options-secondary">
<div class="secondary">
<div class="share-groups">
<ul>
<li>
<button onclick="window.open("http:\/\/www.tumblr.com\/share?v=3\u0026u=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="TUMBLR" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="tumblr." class="share-service-icon share-service-icon-tumblr">
<span>tumblr.</span>
</button>
<span>tumblr.</span>
</li>
<li>
<button onclick="window.open(" http:\/\/pinterest.com\/pin\/create\/button\/?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026description=${encodeURIComponent(data.alternative.title)}\u0026is_video=true\u0026media=http%3A%2F%2Fi3.ytimg.com%2Fvi%2F${data.alternative.id}%2Fhqdefault.jpg", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="PINTEREST" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="pinterest" class="share-service-icon share-service-icon-pinterest">
<span>pinterest</span>
</button>
<span>pinterest</span>
</li>
<li>
<button onclick="window.open("http:\/\/www.blogger.com\/blog-this.g?n=Me+at+the+zoo\u0026source=youtube\u0026b=%3Ciframe+width%3D%22459%22+height%3D%22344%22+src%3D%22%2F%2Fwww.youtube.com%2Fembed%2F${data.alternative.id}%22+frameborder%3D%220%22+allowfullscreen%3E%3C%2Fiframe%3E\u0026eurl=http%3A%2F%2Fi3.ytimg.com%2Fvi%2F${data.alternative.id}%2Fhqdefault.jpg", {'height': 468,'width': 768,'scrollbars': true});return false;" data-service-name="BLOGGER" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Blogger" class="share-service-icon share-service-icon-blogger">
<span>Blogger</span>
</button>
<span>Blogger</span>
</li>
<li>
<button onclick="window.open("http:\/\/www.stumbleupon.com\/submit?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026title=${encodeURIComponent(data.alternative.title)}", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="STUMBLEUPON" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="StumbleUpon" class="share-service-icon share-service-icon-stumbleupon">
<span>StumbleUpon</span>
</button>
<span>StumbleUpon</span>
</li>
</ul>
<ul>
<li>
<button onclick="window.open("http:\/\/www.linkedin.com\/shareArticle?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026title=${encodeURIComponent(data.alternative.title)}\u0026summary=The+first+video+on+YouTube%2C+uploaded+at+8%3A27+P.M.+on+Saturday+April+23rd%2C+2005.+The+video+was+shot+by+Yakov+Lapitsky+at+the+San+Diego+Zoo.%0A%0AThis+video+is+published+under+the+Creative+Commons+Attribution+license%3A+http%3A%2F%2Fcreativecommons.org%2Flicenses%2Fby%2F3.0%2Flegalcode\u0026source=Youtube", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="LINKEDIN" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="LinkedIn" class="share-service-icon share-service-icon-linkedin">
<span>LinkedIn</span>
</button>
<span>LinkedIn</span>
</li>
<li>
<button onclick="window.open("http:\/\/www.myspace.com\/Modules\/PostTo\/Pages\/?t=${encodeURIComponent(data.alternative.title)}\u0026u=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026l=1", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="MYSPACE" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Myspace" class="share-service-icon share-service-icon-myspace">
<span>Myspace</span>
</button>
<span>Myspace</span>
</li>
<li>
<button onclick="window.open("http:\/\/reddit.com\/submit?url=http%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3D${data.alternative.id}%26feature%3Dshare\u0026title=${encodeURIComponent(data.alternative.title)}", {'height': 650,'width': 1024,'scrollbars': true});return false;" data-service-name="REDDIT" class="share-service-button">
<img src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="reddit" class="share-service-icon share-service-icon-reddit">
<span>reddit</span>
</button>
<span>reddit</span>
</li>
</ul>
</div>
</div>
</div>
</div>
<div class="share-panel-embed-container hid">
<div>${localizeString("global.loading.main")}</div>
</div>
<div class="share-panel-email-container hid" data-disabled="true">
<strong>
<a href="">Sign in</a> now!
</strong>
</div>
</div>
<span class="share-panel-hangout">
<img src="//ssl.gstatic.com/s2/oz/images/stars/hangout/1/gplus-hangout-24x100-normal.png" alt="Video call" class="share-panel-hangout-button" title="Watch with your friends.">
</span>
</div>
</div>`;
}
},
sideBar: {
Main: (data) => {
return `<div id="watch-sidebar">
<div class="watch-sidebar-section">
<div id="watch-related-container">
<ul id="watch-related" class="video-list">
</ul>
<ul id="watch-more-related" class="video-list hid">
<li id="watch-more-related-loading">${localizeString("global.loading.suggestions")}</li>
</ul>
</div>
<div class="watch-sidebar-foot">
<p class="content"></p>
</div>
</div>
<span class="yt-vertical-rule-main"></span>
<span class="yt-vertical-rule-corner-top"></span>
<span class="yt-vertical-rule-corner-bottom"></span>
</div>`;
},
suggestedVideo: (videoData) => {
return `<li class="video-list-item">
<a href="https://www.youtube.com/watch?v=${videoData.id}" class="related-video yt-uix-contextlink yt-uix-sessionlink">
<span class="ux-thumb-wrap contains-addto">
<span class="video-thumb ux-thumb yt-thumb-default-120">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${videoData.thumbnail}" alt="Thumbnail"><span class="vertical-align"></span>
</span>
</span>
</span>
<span class="video-time">${videoData.time}</span>
${document.cosmicCat.Template.Buttons.addTo(videoData.id)}
</span>
<span dir="ltr" class="title" title="${videoData.title}">${videoData.title}</span>
<span class="stat attribution">${localizeString("watch.by", videoData === null || videoData === void 0 ? void 0 : videoData.owner.name)}</span>
<span class="stat view-count">${videoData.views}</span>
</a>
</li>`;
}
},
}
}
};
var Comments = {
Main: (data) => {
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
const accountInfo = document.cosmicCat.Storage.get("accountInfo").value || {};
return `<div id="comments-view" data-type="highlights" class="hid">
<div class="comments-section">
<h4><strong>${localizeString("watch.comments.topcomments")}</strong></h4>
<ul class="comment-list top hid"></ul>
</div>
<div class="comments-section">
<h4><strong>${localizeString("watch.comments.allcomments")}</strong> (${((_j = (_h = (_g = (_f = (_e = (_d = (_c = (_b = (_a = ytInitialData.contents.twoColumnWatchNextResults.results) === null || _a === void 0 ? void 0 : _a.results) === null || _b === void 0 ? void 0 : _b.contents) === null || _c === void 0 ? void 0 : _c.find(b => b.itemSectionRenderer)) === null || _d === void 0 ? void 0 : _d.itemSectionRenderer) === null || _e === void 0 ? void 0 : _e.contents) === null || _f === void 0 ? void 0 : _f[0]) === null || _g === void 0 ? void 0 : _g.commentsEntryPointHeaderRenderer) === null || _h === void 0 ? void 0 : _h.commentCount) === null || _j === void 0 ? void 0 : _j.simpleText) || 0}) <a class="comments-section-see-all" href="https://www.youtube.com/all_comments?v=${data.id}">${localizeString("global.seeall")}</a></h4>
<div class="comments-post-container clearfix">
<div class="comments-post-alert ${document.cosmicCat.Storage.get("accountInfo").exists ? "hid" : ""}">
<a href="${document.cosmicCat.data.loginUrl}">Sign In</a> or <a href="https://www.youtube.com/signup">Sign Up</a><span class="comments-post-form-rollover-text"> now to post a comment!</span>
</div>
<form class="comments-post ${document.cosmicCat.Storage.get("accountInfo").exists ? "" : "hid"}" method="post">
<input type="text" id="session" hidden="">
<div class="yt-alert yt-alert-default yt-alert-error hid comments-post-message">
<div class="yt-alert-icon">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" class="icon master-sprite" alt="Alert icon">
</div>
<div class="yt-alert-buttons"></div><div class="yt-alert-content" role="alert"></div></div>
<a href="/profile" class="yt-user-photo comments-post-profile">
<span class="video-thumb ux-thumb yt-thumb-square-46">
<span class="yt-thumb-clip">
<span class="yt-thumb-clip-inner">
<img src="${accountInfo.pfp}" alt="${accountInfo.name}" width="46"><span class="vertical-align"></span>
</span>
</span>
</span>
</a>
<div class="comments-textarea-container" onclick="document.cosmicCat.Comments.Form.init();">
<img src="//s.ytimg.com/yt/img/pixel-vfl3z5WfW.gif" alt="" class="comments-textarea-tip">
<label class="comments-textarea-label" data-upsell="comment">${localizeString("watch.comments.respond")}</label> <div class="yt-uix-form-input-fluid yt-grid-fluid ">
<textarea id="" class="yt-uix-form-textarea comments-textarea" onfocus="document.cosmicCat.Comments.Form.init();" data-upsell="comment" name="comment"></textarea>
</div>
</div>
<p class="comments-remaining">
${localizeString("watch.comments.charactersremain")}
</p>
<p class="comments-threshold-countdown hid">
<span class="comments-threshold-count"></span> ${localizeString("watch.comments.secondsremain")}
</p>
<p class="comments-post-buttons">
<button type="submit" class="comments-post yt-uix-button yt-uix-button-default" onclick=";return true;" role="button">
<span class="yt-uix-button-content">${localizeString("buttons.comments.post")} </span>
</button>
</p>
</form>
</div>
<ul class="comment-list all hid"></ul>
</div>
<div class="comments-section">
<div class="comments-pagination" data-Ajax-enabled="true">
<div class="yt-uix-pager" role="navigation">
<a id="next-btn" onclick="document.cosmicCat.Comments.next(this.getAttribute('data-token'), this.getAttribute('data-page'))" class="yt-uix-button yt-uix-sessionlink yt-uix-pager-button yt-uix-button-default hid" data-page="2"><span class="yt-uix-button-content">Next »</span></a>
</div>
</div>
</div>
<ul>
<li class="hid" id="parent-comment-loading">${localizeString("global.loading.comment")}</li>
</ul>
<div id="comments-loading">${localizeString("global.loading.main")}</div>
</div>
</div>`;
},
Comment: (data) => {
return `<li class="comment yt-tile-default" data-author-id="${data.author.id}" data-id="${data.id}" data-score="-1">
<div class="comment-body">
<div class="content-container">
<div class="content">
<div class="comment-text" dir="ltr">
<p>${data.text}</p>
</div>
<p class="metadata">
<span class="author">
<a href="${data.author.url}" class="yt-uix-sessionlink yt-user-name" data-sessionlink="" dir="ltr">${data.author.name}</a>
</span>
<span class="time" dir="ltr">
<a dir="ltr" href="https://www.youtube.com/watch?v=${data.id}&lc=${data.id}">${data.time}</a>
</span>
${data.likes ? `<span dir="ltr" class="comments-rating-positive" title="">
${data.likes}<img class="comments-rating-thumbs-up" style="vertical-align: bottom !important;" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif">
</span>` : ""}
</p>
</div>
<div class="comment-actions">
<span class="yt-uix-button-group">
<button type="button" class="start comment-action-vote-up comment-action yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" onclick=";return false;" title="Vote Up" data-action="vote-up" data-tooltip-show-delay="300" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-comment-vote-up" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Vote Up">
<span class="yt-valign-trick"></span>
</span>
</button><button type="button" class="end comment-action-vote-down comment-action yt-uix-button yt-uix-button-default yt-uix-tooltip yt-uix-button-empty" onclick=";return false;" title="Vote Down" data-action="vote-down" data-tooltip-show-delay="300" role="button">
<span class="yt-uix-button-icon-wrapper">
<img class="yt-uix-button-icon yt-uix-button-icon-watch-comment-vote-down" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="Vote Down">
<span class="yt-valign-trick"></span>
</span>
</button>
</span>
<span class="yt-uix-button-group">
<button type="button" class="start comment-action yt-uix-button yt-uix-button-default" onclick=";return false;" data-action="reply" role="button">
<span class="yt-uix-button-content">Reply </span>
</button><button type="button" class="end yt-uix-button yt-uix-button-default yt-uix-button-empty" onclick=";return false;" data-button-has-sibling-menu="true" role="button" aria-pressed="false" aria-expanded="false" aria-haspopup="true" aria-activedescendant="">
<img class="yt-uix-button-arrow" src="//s.ytimg.com/yts/img/pixel-vfl3z5WfW.gif" alt="">
<div class=" yt-uix-button-menu yt-uix-button-menu-default" style="display: none;">
<ul>
<li class="comment-action-remove comment-action" data-action="remove">
<span class="yt-uix-button-menu-item">Remove</span>
</li>
<li class="comment-action" data-action="flag">
<span class="yt-uix-button-menu-item">Flag for spam</span>
</li>
<li class="comment-action-block comment-action" data-action="block">
<span class="yt-uix-button-menu-item">Block User</span>
</li>
<li class="comment-action-unblock comment-action" data-action="unblock">
<span class="yt-uix-button-menu-item">Unblock User</span>
</li>
</ul>
</div>
</button>
</span>
</div>
</div>
</div>
</li>`;
},
};
var supportedBrowsers = {
Main: () => {
return `<div id="content">
<div class="ytg-wide">
</div>
<div id="marketing-header" class="supported-browsers ytg-base">
<div class="ytg-wide ytg-box">
<div class="ytg-3col">
<h2>Oops, your web browser will be unsupported soon.</h2>
<p>YouTube works with a wide range of browsers. However, if you'd like to use many of our latest and greatest features, please upgrade to a modern, fully supported browser.</p>
<p>Find the latest versions of our supported browsers below.</p>
<p>
<button href="/" type="button" class=" yt-uix-button yt-uix-button-default" onclick=";window.location.href=this.getAttribute('href');return false;" role="button">
<span class="yt-uix-button-content">No thanks </span>
</button>
</p>
</div>
<div class="ytg-3col ytg-last">
<img src="//s.ytimg.com/yts/img/marketing/browsers/mr-meh-vflAEr4Cy.png" style="_background: none;filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='//s.ytimg.com/yts/img/marketing/browsers/mr-meh-vflAEr4Cy.png',sizingMethod='scale');" alt="Browser illustration" align="top">
</div>
</div>
</div>
<div id="marketing-content" class="supported-browsers ytg-base ytg-box">
<div class="ytg-wide">
<h2>Get the latest</h2>
<div class="col yt-grid-4 yt-tile-static ">
<h3>
<a onmousedown="yt.tracking.track('browserupgrade_page', 'browser=chrome')" href="https://www.google.com/chrome/index.html?brand=CHNY&utm_campaign=en&utm_source=en-et-youtube&utm_medium=et">
<img src="//s.ytimg.com/yts/img/marketing/browsers/chrome-vflbrSn5t.png" alt="">Chrome
</a>
</h3>
<p>by Google</p>
</div>
<div class="col yt-grid-4 yt-tile-static ">
<h3>
<a onmousedown="yt.tracking.track('browserupgrade_page', 'browser=firefox')" href="https://www.mozilla.com/?from=sfx&uid=267821&t=449">
<img src="//s.ytimg.com/yts/img/marketing/browsers/firefox-vflkT4oSN.png" alt="">Firefox
</a>
</h3>
<p>by Mozilla</p>
</div>
<div class="col yt-grid-4 yt-tile-static last">
<h3>
<a onmousedown="yt.tracking.track('browserupgrade_page', 'browser=safari')" href="https://web.archive.org/web/20121029090305/http://www.apple.com/safari/">
<img src="//s.ytimg.com/yts/img/marketing/browsers/safari-vflIOoRbM.png" alt="">Safari
</a>
</h3>
<p>by Apple</p>
</div>
</div>
</div>
</div>`;
}
};
var TransSatanJumpscare = {
Main: () => {
return `<link rel="stylesheet" href="//cosmic-cat-yt.github.io/cosmic-cat/666-transrights.css"/>
<iframe src="https://youtube.com/embed/kVpPlWlHMrA?autoplay=1" width="1" height="1" allow="autoplay"></iframe>
<div id="s"><div id="e"></div></div>`;
}
};
class Template {
constructor(cc) {
this.errorNotFound = errorNotFound;
this.Alerts = Alerts;
this.Browse = {
Main: BrowseMain,
Subnav: BrowseSubnav,
Content: BrowseContent
};
this.Comments = Comments;
this.Channels = {
Channels3: {
Main: Channels3Main,
Header: Channels3Header,
Content: Channels3Content,
primaryPane: {
featured: Channels3PrimaryPaneFeatured,
browseVideos: Channels3PrimaryPaneBrowseVideos
},
secondaryPane: Channels3SecondaryPane,
creatorBar: Channels3CreatorBar
},
Channels2: {
Main: Channels2Main,
playlistNavigator: Channels2PlaylistNavigator,
moduleContainer: Channels2ModuleContainer,
Stylesheet: Channels2Stylesheet
},
Channels1: Channels1
};
this.Playlist = Playlist;
this.Search = Search;
this.Masthead = Masthead;
this.Footer = Footer;
this.Homepage = Homepage;
this.Settings = Settings;
this.Buttons = Buttons;
this.Watch = Watch;
this.supportedBrowsers = supportedBrowsers;
this.TransSatanJumpscare = TransSatanJumpscare;
this.cc = cc;
}
}
// Cosmic Cat code. Authored by Cosmic Cat Maintainers, code available under the public domain.
class CosmicCat {
constructor() {
this.data = new Data;
this.Settings = new Settings$1(this);
this.Account = new Account(this);
this.Ajax = new Ajax(this);
this.Template = new Template(this);
this.Utils = new Utils(this);
this.Pagination = new Pagination;
this.Comments = new Comments$1(this);
this.Search = new Search$1(this);
this.Channels = Channels;
this.Playlists = Playlists;
this.Home = Home;
this.Subscriptions = new Subscriptions(this);
this.Animations = new Animations;
this.watch = watch;
this.Browse = new Browse(this);
this.vorapisPlayer = vorapisPlayer;
this.Storage = new Storage;
this.pageRenderer = new PageRenderer(this);
this.Actions = new Actions(this);
this.picker = new Picker(this);
this.www = www;
}
Alert(a, b) {
this.pageRenderer.set("#alerts", this.Template.Alerts(a, b));
}
toggleElm(params) {
const elm = document.querySelector(params);
if (!params)
return console.error("toggleElm", params + "is not a valid HTMLElement");
console.debug("toggleElm", "toggled", params);
if (elm.classList.contains("hid")) {
elm.classList.remove("hid");
}
else {
elm.classList.add("hid");
}
}
null() {
return null;
}
}
((external) => __awaiter(void 0, void 0, void 0, function* () {
GM_registerMenuCommand("Open (settings)", () => window.location.replace("/cosmic_cat"));
let cosmicCat = new CosmicCat;
external.document.cosmicCat = cosmicCat;
cosmicCat.Storage.init();
cosmicCat.Account.checkLogin();
const OBJ_STYLE_DARK = `* {--dark-noise: url(${document.cosmicCat.data.darkNoiseBg}); --shadow-color: #110f0f; --nero-color-primary: #201e1e; --nero-color-secondary: #242323; --gray-color: #a2a2a2; --silver-color: #bfbfbf; --night-rider-color: #2f2f2f; --white-color: #fff; --black-color: #000;}
body, #masthead-container
{background: var(--dark-noise) !important}
#masthead-search-terms input
{background: var(--black-color) !important; color: var(--white-color);}
#feed, #feed-background, .yt-tile-static, .yt-tile-visible, .yt-tile-default:hover, .yt-tile-default.video-list-item a:hover, #watch-sidebar .video-list-item a:hover
{ background: var(--nero-color-primary) !important; border-bottom-color: var(--nero-color-primary) !important; }
.feed-item-container:hover
{background: var(--nero-color-secondary) !important;}
#masthead-nav a, #masthead-user a, .metadata .view-count, .metadata .view-count, .feed-item-actions-line, .heading .header-container, .browse-item-content h3 a, #eow-title, .watch-view-count, #watch-uploader-info, .title, .yt-uix-button-content
{color: var(--silver-color) !important;}
.feed-item-container .feed-item-main, .feed-item-container:hover
{border-bottom: 1px solid var(--night-rider-color) !important;}
.feed-item-container:hover
{border-top: 1px solid var(--night-rider-color) !important;}
#footer ul {text-shadow: none;}
#masthead-user-expander .yt-uix-expander-head, #masthead-gaia-user-wrapper, #masthead-gaia-photo-wrapper
{border: 1px solid transparent;}
#watch-description .expand, #watch-description .collapse
{filter: invert();}
#search-btn .yt-uix-button-content
{filter: invert(); color: var(--gray-color);}
#masthead-expanded-container, #filter-dropdown
{box-shadow: inset 0 5px 5px var(--shadow-color) !important;}
img#logo
{background: url(${document.cosmicCat.data.darkyoutubelogo}) !important; background-size: 100px !important;}
#masthead-expanded-loading-message, #search-header h2, .yt-uix-button-content, label, .comment-text, #eow-description, #watch-description-extras, .num-results, #filter-dropdown, .enable-fancy-subscribe-button .yt-uix-button-subscription:hover .yt-uix-button-content, .yt-lockup-content *, .comments-section strong, #watch-description-extras h4
{color: var(--white-color) !important}
#masthead-search-terms, #search-btn
{border-color: #262626 !important; background: none !important;}
.yt-uix-button-default, .yt-subscription-button-js-default, .yt-uix-button-panel:hover .yt-uix-button-text, body .yt-uix-button-default[disabled]
{box-shadow: none !important; text-shadow: 0 1px 0 #000; border-color: #262626; background-image: linear-gradient(to bottom,#000 0,#202020 100%) !important;}
.subscription-button-with-recommended-channels .yt-uix-button-content
{color: #555 !important;}
.metadata-inline .yt-uix-button-content
{color: var(--black-color) !important;}
.yt-horizontal-rule
{border-top-color: var(--black-color) !important; border-bottom-color: var(--nero-color-primary) !important;}
`;
function _i18n() {
const obj = {
setTranslation: function (params) {
return fetch(document.cosmicCat.data.i18nfolder + `${params}.json`)
.then((response) => response.json())
.then((data) => {
document.cosmicCat.Storage.add("i18n", data);
window.location.reload();
return true;
})
.catch((error) => {
alert(params + " is not translated yet.\n\nContribute: https://github.com/cosmic-cat-yt/cosmic-cat-i18n");
console.error(error, "reverting to fallback.");
return false;
//document.cosmicCat.func.addToStorage("i18n", this.useFallback());
});
},
useFallback: function () {
//return document.cosmicCat.func.getFromStorage("i18n.fallback");
},
getTranslation: function () {
return document.cosmicCat.Storage.get("i18n").value;
}
};
const STORAGE = document.cosmicCat.Storage.get("i18n.setup");
if (STORAGE.value !== "1") {
obj.setTranslation("en");
document.cosmicCat.Storage.add("i18n.setup", "1");
}
return obj;
}
external._i18n = _i18n;
const localizeString = (varr, DOM) => {
var _a, _b, _c, _d;
const lang = _i18n().getTranslation();
var i18n;
try {
i18n = varr.split('.').reduce((o, i) => o[i] || "", lang.json) || "<\bno i18n string>";
}
catch (_e) {
// Attempt to refetch missing translations.
_i18n().setTranslation("en");
}
// really need to get rid of this and simplify the process.
try {
switch (varr) {
case "watch.uploaderinfo":
i18n = i18n.replace(/%s/g, `<a href="https://www.youtube.com${(_b = (_a = DOM === null || DOM === void 0 ? void 0 : DOM.secondary) === null || _a === void 0 ? void 0 : _a.owner) === null || _b === void 0 ? void 0 : _b.url}/featured" class="yt-uix-sessionlink yt-user-name author" rel="author" dir="ltr">${(_d = (_c = DOM === null || DOM === void 0 ? void 0 : DOM.secondary) === null || _c === void 0 ? void 0 : _c.owner) === null || _d === void 0 ? void 0 : _d.name}</a>`);
i18n = i18n.replace(/%r/g, `<span id="eow-date" class="watch-video-date">${DOM === null || DOM === void 0 ? void 0 : DOM.primary.upload}</span>`);
break;
case "home.feed.uploadedavideo":
i18n = i18n.replace(/%s/g, `<span class="feed-item-owner"><a href="${DOM === null || DOM === void 0 ? void 0 : DOM.url}/featured" class="yt-uix-sessionlink yt-user-name" dir="ltr">${DOM === null || DOM === void 0 ? void 0 : DOM.name}</a></span>`);
break;
case "watch.from":
i18n = i18n.replace(/%s/g, `<span id="playnav-curvideo-channel-name"><a href="${window.location.href}">${DOM}</a></span>`);
break;
case "home.feed.islive":
i18n = i18n.replace(/%s/g, `<span class="feed-item-owner"><a href="${DOM === null || DOM === void 0 ? void 0 : DOM.url}" class="yt-uix-sessionlink yt-user-name" dir="ltr">${DOM === null || DOM === void 0 ? void 0 : DOM.name}</a></span>`);
break;
case "watch.by":
i18n = i18n.replace(/%s/g, `<span class="yt-user-name" dir="ltr">${DOM}</span>`);
break;
case "search.channels.by":
i18n = i18n.replace(/%s/g, `<a href="https://www.youtube.com${DOM === null || DOM === void 0 ? void 0 : DOM.url}" class="yt-uix-sessionlink yt-user-name" dir="ltr">${DOM === null || DOM === void 0 ? void 0 : DOM.name}</a>`);
break;
case "stats.likesdislikes":
i18n = i18n.replace(/%s/g, `<span class="likes"></span>`);
i18n = i18n.replace(/%r/g, `<span class="dislikes"></span>`);
break;
case "playlists.body.primaryPane.items.video.by":
i18n = i18n.replace(/%s/g, `${DOM}`);
break;
case "search.playlists.by":
i18n = i18n.replace(/%s/g, `<a href="${DOM === null || DOM === void 0 ? void 0 : DOM.url}" class="yt-user-name" dir="ltr">${DOM === null || DOM === void 0 ? void 0 : DOM.name}</a>`);
break;
case "playlists.body.secondaryPane.aboutSection.about":
i18n = i18n.replace(/%s/g, `${DOM}`);
break;
case "playlists.body.secondaryPane.aboutSection.creatorLinks.playlists":
i18n = i18n.replace(/%s/g, `All`);
i18n = i18n.replace(/%r/g, `${DOM}`);
break;
case "playlists.header.channelAuthor":
i18n = i18n.replace(/%s/g, `<a href="${DOM === null || DOM === void 0 ? void 0 : DOM.url}">${DOM === null || DOM === void 0 ? void 0 : DOM.name}</a>`);
break;
case "channels.3.body.secondaryPane.userProfile.about":
i18n = i18n.replace(/%s/g, `${DOM}`);
break;
case "channels.3.body.secondaryPane.userProfile.createdBy.by":
i18n = i18n.replace(/%s/g, `<span class="yt-user-name" dir="ltr">${DOM}</span>`);
break;
case "watch.comments.charactersremain":
i18n = i18n.replace(/%s/g, `<span class="comments-remaining-count" data-max-count="500">500</span>`);
break;
}
}
catch (_f) { }
return i18n;
};
external.localizeString = localizeString;
if (window.location.pathname.match(/\/feed\/explore/i)) {
document.cosmicCat.Utils.waitForElm("#page").then(function () {
let obj = ["trending", "music", "film", "gaming", "sports"];
for (let i = 0; i < obj.length; i++) {
Promise.all([
document.cosmicCat.Ajax.Fetch(`https://www.youtube.com${document.cosmicCat.Utils.listCategories(obj[i]).href}`, document.cosmicCat.Browse._Data)
]).then(res => {
let videos = "";
for (let i = 0; i < res[0].length; i++) {
videos += document.cosmicCat.Template.Browse.Content.Video(res[0][i]);
}
let categories = document.cosmicCat.Template.Browse.Content.Category(document.cosmicCat.Utils.listCategories(obj[i]), videos);
document.cosmicCat.pageRenderer.add("#browse-main-column", categories);
});
}
});
}
if ("onbeforescriptexecute" in document) {
document.addEventListener("beforescriptexecute", (e) => {
let t = e.target;
(t.src.search("base.js") > -1 ||
t.src.search("desktop_polymer.js") > -1 ||
t.src.search("network.vflset") > -1 ||
t.src.search("desktop_polymer_enable_wil_icons") > -1 ||
t.src.search("spf") > -1) &&
(e.preventDefault(), t.remove());
});
}
else {
(document.cosmicCat.Utils.waitForElm("script#base-js").then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm('script[src*="js/th"]').then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm('script[src*="s/player"]').then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm('script[src*="cast_sender"]').then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm('script[src*="desktop_polymer_enable_wil_icons"]').then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm('script[src*="network.vflset"]').then(function (e) {
e.remove();
}),
document.cosmicCat.Utils.waitForElm("script[src*=spf]").then(function (e) {
e.remove();
}));
}
document.querySelector("html").removeAttribute("style"),
document.querySelector("html").removeAttribute("class"),
document.querySelector("html").removeAttribute("dark"),
document.querySelector("html").removeAttribute("system-icons"),
document.querySelector("html").removeAttribute("typography"),
document.querySelector("html").removeAttribute("typography-spacing"),
document.querySelector("html").removeAttribute("darker-dark-theme"),
document.querySelector("html").removeAttribute("darker-dark-theme-deprecate");
document.cosmicCat.Utils.waitForElm("head").then(() => {
var t = document.createElement("head");
t.setAttribute("litterbox", "");
document.querySelector("html").prepend(t);
document.querySelector("html head:not([litterbox])").remove();
var y = document.createElement("script");
y.setAttribute("id", "www-searchbox");
y.setAttribute("src", "//s.ytimg.com/yts/jsbin/www-searchbox-vflOEotgN.js");
document.querySelector("head").append(y);
var o = document.createElement("title");
o.innerText = "YouTube - Broadcast Yourself.";
document.querySelector("head").append(o);
var x = document.createElement("link");
x.setAttribute("rel", "icon");
x.setAttribute("href", "//s.ytimg.com/yt/favicon-refresh-vfldLzJxy.ico");
document.querySelector("head").append(x);
var u = document.createElement("link");
u.setAttribute("rel", "shortcut icon");
u.setAttribute("href", "//s.ytimg.com/yt/favicon-refresh-vfldLzJxy.ico");
document.querySelector("head").append(u);
// Doesn't always load on FF
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-core-vfleLhVpH.css");
});
document.cosmicCat.Utils.waitForElm("ytd-app").then((e) => __awaiter(void 0, void 0, void 0, function* () {
e.remove();
document.querySelector("html").setAttribute("dir", "ltr");
document.querySelector("body").setAttribute("id", "");
document.querySelector("body").setAttribute("ytdataloaded", "");
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-player-vfluwFMix.css");
if (window.location.pathname == "/" || window.location.pathname == "/feed/subscriptions") {
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-guide-vfljovH6N.css");
}
if (document.cosmicCat.Channels.isChannelsPage()) {
let style = {
3: ["//s.ytimg.com/yts/cssbin/www-channels3-vflIpog6R.css", "//s.ytimg.com/yts/cssbin/www-watch-inlineedit-vflg-l3kd.css"],
2: ["//s.ytimg.com/yt/cssbin/www-refresh-vflzVUPsm.css", "//s.ytimg.com/yt/cssbin/www-the-rest-vflNb6rAI.css", "//s.ytimg.com/yt/cssbin/www-channel_new-vflrWkVe_.css"],
1: ["//cosmic-cat-yt.github.io/cosmic-cat/www-channel.css", "//cosmic-cat-yt.github.io/cosmic-cat/base_all-vfl42963.css"]
};
let boop = style[document.cosmicCat.Storage.get("channel_mode").value];
for (let i = 0; i < boop.length; i++) {
document.cosmicCat.Utils.addStyle(boop[i]);
}
(document.cosmicCat.Storage.get("channel_mode").value == "2") && document.querySelector("#www-core-css").remove();
}
if (window.location.pathname.split("/")[1].match(/playlist/i)) {
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-playlist-vflWjxI-w.css");
}
if (window.location.pathname.match(/\/feed\/explore/i)) {
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-videos-nav-vflWHHWFS.css");
document.cosmicCat.Utils.addStyle("//s.ytimg.com/yts/cssbin/www-browse-new-vflUr2lEG.css");
}
document.body.setAttribute("class", "date-20121030 ltr ytg-old-clearfix guide-feed-v2");
document.body.setAttribute("cosmic-cat", "");
if (document.cosmicCat.Storage.get("dark").value == "1") {
var p = document.createElement("style");
p.setAttribute("id", "www-yt-dark");
p.innerText = OBJ_STYLE_DARK;
document.querySelector("head").append(p);
}
// 壊れています
// バージョン文字列の比較は誤った部分文字列を取得するようです
// そのため、比較は失敗します
// TODO: Port to REGEX
// Check for updates here, because Tampermonkey's "Auto-updater" is SHIT!
//fetch("https://raw.githubusercontent.com/cosmic-cat-yt/cosmic-cat/main/cosmic-cat.user.js").then(a => a.text()).then(a => {
// var b = (a.substr(parseInt(a.search("@version") + 14)).substr(0, parseInt(a.search("@version") - 86)));
// (GM_info.script.version !== b) && (update = !0);
//
// console.debug("[Updater] Current version:", GM_info.script.version, "|", "GitHub version:", b);
//});
fetch("https://raw.githubusercontent.com/cosmic-cat-yt/cosmic-cat-i18n/main/version.json").then(a => a.json()).then(a => {
(document.cosmicCat.Storage.get("storageVer").value !== a.version) && (document.cosmicCat.Storage.add("storageVer", a.version),
_i18n().setTranslation(document.cosmicCat.Storage.get("lang").value));
}).catch(err => console.error(err));
setTimeout(function () {
var _a, _b;
return __awaiter(this, void 0, void 0, function* () {
if (!document.cosmicCat.Account.isLoggedIn()) {
yield document.cosmicCat.Account.fetch();
}
/* Render main body */
const bodyDOM = document.createElement("div");
bodyDOM.setAttribute("id", "page");
document.cosmicCat.data.lang = document.cosmicCat.data.lang[document.cosmicCat.Storage.get("lang").value];
document.cosmicCat.data.country = (_b = (_a = window.yt) === null || _a === void 0 ? void 0 : _a.config_) === null || _b === void 0 ? void 0 : _b.GL;
let OBJ_MASTH = "";
let OBJ_USER = "";
if (document.cosmicCat.Account.isLoggedIn()) {
OBJ_USER = document.cosmicCat.Template.Masthead.User.loggedIn();
OBJ_MASTH = document.cosmicCat.Template.Masthead.Expander();
}
else {
OBJ_USER = document.cosmicCat.Template.Masthead.User.loggedOut();
}
var OBJ_MASTHEAD = document.cosmicCat.Template.Masthead.Main();
var OBJ_FOOTER = document.cosmicCat.Template.Footer();
bodyDOM.innerHTML += `<div id="masthead-container">
${OBJ_MASTHEAD}
</div>
<div id="content-container">
</div>
${OBJ_FOOTER}
<style id="fix-hid">.hid {display: none !important;}</style>`;
document.querySelector("body").appendChild(bodyDOM);
document.cosmicCat.pageRenderer.set("#masthead-user", OBJ_USER);
document.cosmicCat.pageRenderer.add("#masthead-container", OBJ_MASTH);
document.querySelector("body").setAttribute("ythtmlloaded", "");
document.cosmicCat.Utils.waitForElm2().then(() => {
});
try {
yt.www.masthead.searchbox.init();
}
catch (err) {
try {
setTimeout(() => yt.www.masthead.searchbox.init(), 1000);
}
catch (err) {
console.error("[Searchbox] Couldn't init!\n", err, "\nTrying again one last time.");
try {
setTimeout(() => yt.www.masthead.searchbox.init(), 1000);
}
catch (err) {
console.error("[Searchbox] Couldn't init!\n", err);
}
}
console.error("[Searchbox] Couldn't init!\n", err, "\nTrying again in 1 second.");
}
});
}, 1);
}));
document.cosmicCat.Utils.waitForElm("body[ythtmlloaded]").then(function () {
try {
document.cosmicCat.www[document.cosmicCat.Utils.currentPage()]();
}
catch (err) {
console.error("[pageRenderer] Either the page does not exist, or a problem has occurred.\n", err);
document.cosmicCat.www["404"]();
}
});
document.cosmicCat.Utils.waitForElm("#watch-page-skeleton").then(function (a) {
a.style.display = "none";
});
document.cosmicCat.Utils.waitForElm('#player').then(function (e) {
//e.remove();
});
document.cosmicCat.Utils.waitForElm("iframe[src*=error]").then(function () {
document.cosmicCat.www["404"]();
});
document.cosmicCat.Utils.waitForElm(".yt-main").then(function () {
document.cosmicCat.www["404"]();
});
addHandler("click", "yt-uix-button-default", cosmicCat.Actions.handleButton);
addHandler("click", "yt-uix-button-text", cosmicCat.Actions.handleButton);
addHandler("click", "yt-subscription-button", cosmicCat.Actions.handleSubscribeButton);
addHandler("click", "subscribe-button", cosmicCat.Actions.handleSubscribeButton);
addHandler("click", "masthead-user-menu-expander", cosmicCat.Actions.handleExpander);
addHandler("click", "guide-item-container", cosmicCat.Actions.handleGuideItem);
init();
}))(window);
exports.CosmicCat = CosmicCat;
return exports;
})({});