import { e } from '../../index-6137f488.js'; import { e as e$2 } from '../../background.injected-af36b849.js'; import { n, e as e$4 } from '../../get_stream_details-b6177000.js'; import { d as dt, t } from '../../parse_token.util-ed270559.js'; import { e as e$3 } from '../../fetch_youtube-71c76849.js'; import { s } from '../../router.interface-6cdbc015.js'; import { e as e$1 } from '../../style-inject.es-a0e1a0ba.js'; function u(t) { if (!t) return 0; t = t.toLowerCase(); const e = /\((.+)\)/.exec(t); if (!e) return 1; const n = e[1].split(/\s/), i = parseInt(n[0]); return isNaN(i) ? 0 : n[1].startsWith("year") ? 12 * parseInt(n[0]) : parseInt(n[0]) } function d(t, e) { const n = e; for (let e = 0; e < n.length; e++) if (n[e][0] > t) return n[e - 1][1]; return n[n.length - 1][1] } function l(t, e, n, i) { const a = e(t.authorExternalChannelId); ! function(t, e) { (null == e ? void 0 : e.a) && (t.authorName = { simpleText: e.a }); }(t, a), function(t, e) { var n, i; t.authorBadges || (t.authorBadges = []); for (const a of t.authorBadges) { const t = a.liveChatAuthorBadgeRenderer; (null === (n = t.icon) || void 0 === n ? void 0 : n.iconType) ? t._mtvType = null === (i = t.icon) || void 0 === i ? void 0 : i.iconType.toLowerCase(): t.customThumbnail && (t._mtvType = "member"), "moderator" === t._mtvType && (delete t.icon, t._mtvType = "moderator", t.customThumbnail = { thumbnails: [{ url: e, width: 18, height: 18 }] }); } }(t, i), function(t, e, n) { if ((null == n ? void 0 : n.b) && !(n.b <= 0)) for (const i of t.authorBadges) { const t = i.liveChatAuthorBadgeRenderer; if ("member" !== t._mtvType) continue; const a = u(t.tooltip); if (0 === a) continue; const o = a + n.b, r = `Member (${o} months)`, s = d(o, e); t.customThumbnail = s, delete t.icon, t.tooltip = r, t.accessibility.accessibilityData.label = r; } }(t, n, a); } const h = /[\s.,?!]/; function f(t) { const e = []; let n = 0; for (let i = 0; i < t.length - 1; i++) h.test(t[i]) !== h.test(t[i + 1]) && (e.push(t.substring(n, i + 1)), n = i + 1); return e.push(t.substring(n)), e } function m(t$1) { let e; if (t$1.provider === t.Twitch) e = `https://static-cdn.jtvnw.net/emoticons/v2/${t$1.id}/static/dark/1.0`; else if (t$1.provider === t.FFZ) e = `https://cdn.frankerfacez.com/emote/${t$1.id}/1`; else { if (t$1.provider !== t.BTTV) return; e = `https://cdn.betterttv.net/emote/${t$1.id}/1x`; } return { emojiId: "mogultv-" + t$1.name + "-" + t$1.id, image: { thumbnails: [{ url: e }], accessibility: { accessibilityData: { label: t$1.name } } }, isCustomEmoji: !0, searchTerms: [t$1.name], shortcuts: [":" + t$1.name + ":", t$1.name] } } const g = ["#ff0000", "#009000", "#b22222", "#ff7f50", "#9acd32", "#ff4500", "#2e8b57", "#daa520", "#d2691e", "#5f9ea0", "#1e90ff", "#ff69b4", "#00ff7f", "#a244f9"]; /*! * cookie * Copyright(c) 2012-2014 Roman Shtylman * Copyright(c) 2015 Douglas Christopher Wilson * MIT Licensed */ var v = function(t, e) { if ("string" != typeof t) throw new TypeError("argument str must be a string"); for (var n = {}, i = e || {}, a = t.split(p), o = i.decode || y, r = 0; r < a.length; r++) { var s = a[r], c = s.indexOf("="); if (!(c < 0)) { var u = s.substr(0, c).trim(), d = s.substr(++c, s.length).trim(); '"' == d[0] && (d = d.slice(1, -1)), null == n[u] && (n[u] = w(d, o)); } } return n }, y = decodeURIComponent, p = /; */; function w(t, e) { try { return e(t) } catch (e) { return t } } var b; class A { constructor(t) { this.gatewayService = t; } addAliasesToMessage(t) { l(t, (t => this.gatewayService.getUserInfo(t)), this.gatewayService.badgeList, ""); } } class T { constructor(t) { this.gatewayService = t; } addTwitchEmotesToMessage(t) { return function(t, e) { const n = []; for (const i of t.runs) if ("string" == typeof i.text) { const { text: t } = i; let a = 0, o = 0; const r = f(t); let s = !1; for (const i of r) { const r = e("🌝" === i ? "Kappa" : i); r && (s = !0, a > 0 && n.push({ text: t.substring(o, a) }), n.push({ emoji: r }), o = a + i.length), a += i.length; } s ? n.push({ text: t.substring(o, a) }) : n.push(i); } else if ("🌝" === i.emoji.emojiId) { const t = e("Kappa"); t && n.push({ emoji: t }); } else n.push(i); return t.runs = n, t }(t, (t => this.gatewayService.getEmote(t))) } } class x extends e.exports.EventEmitter { constructor(t) { super(), this.backgroundService = t, this.badgeList = [], this.emoteCache = new Map, t.getLiveStorageValue("auth.token", dt).then((t => this.myUserInfo = t)), this.fetchUserInfo(), this.fetchEmotes(), this.fetchBadges(), setInterval((() => { this.fetchUserInfo(), this.fetchEmotes(), this.fetchBadges(); }), 3e5); } async fetchBadges() { const t = await this.backgroundService.fetch("/gateway/badges"); if (!s(t)) return; const e = t.body.sort(((t, e) => t.months - e.months)); this.badgeList = e.map((t => [t.months, { thumbnails: [{ url: t.url, width: 16, height: 16 }] }])), this.emit("badges", this.badgeList); } async fetchEmotes() { const t = await this.backgroundService.fetch("/gateway/emotes"); if (s(t)) { this.emoteCache.clear(); for (const e of t.body) { const t = m(e); t && this.emoteCache.set(e.name, t); } this.emit("emotes", this.emoteCache); } } async fetchUserInfo() { const t = await this.backgroundService.fetch("/gateway/users"); s(t) && (this.infoCache = new Map(t.body), this.emit("users", this.infoCache)); } getSerializedMetadata(t) { const e = t.links.find((e => e.prv === t.prv)), n = { a: null == e ? void 0 : e.name, b: t.meta.sub, c: t.meta.col }; return Object.values(n).filter((t => void 0 !== t)).length > 0 ? n : void 0 } getUserInfo(t) { var e, n, i; if ((null === (n = null === (e = this.myUserInfo) || void 0 === e ? void 0 : e.value) || void 0 === n ? void 0 : n.sub) === t) { const t = this.getSerializedMetadata(this.myUserInfo.value); if (t) return t } return null === (i = this.infoCache) || void 0 === i ? void 0 : i.get(t) } getEmote(t) { var e; return null === (e = this.emoteCache) || void 0 === e ? void 0 : e.get(t) } } async function I(t, n) { await customElements.whenDefined(t); const i = customElements.get(t); if (!i) return void console.warn(`Polymer: ${t} not found`); const a = i.prototype[n.functionName]; i.prototype[n.functionName] = function(...t) { if (n.ludwigOnly && !e$4()) return a.apply(this, t); if (n.type === b.OverrideFunction) try { return n.function.apply(this, t) } catch (t) { console.error(JSON.stringify(n)), console.error(t); } if (n.type === b.RunBefore) try { n.function.apply(this, t); } catch (t) { console.error(t); } let i = a.apply(this, t); if (n.type === b.RunAfter) try { i = n.function.apply(this, [i]); } catch (t) { console.error(t); } return i }; }! function(t) { t[t.OverrideFunction = 0] = "OverrideFunction", t[t.RunBefore = 1] = "RunBefore", t[t.RunAfter = 2] = "RunAfter"; }(b || (b = {})); const B = (t, e, { LudwigOnly: n }) => ({ functionName: t, function: e, ludwigOnly: n || !1, type: b.OverrideFunction }), E = (t, e, { LudwigOnly: n }) => ({ functionName: t, function: e, ludwigOnly: n || !1, type: b.RunBefore }); function C(t, n, i) { I("yt-live-chat-item-list-renderer", E("handleAddChatItemAction_", (function(e) { e.item.liveChatTextMessageRenderer && (t.addTwitchEmotesToMessage(e.item.liveChatTextMessageRenderer.message), n.addAliasesToMessage(e.item.liveChatTextMessageRenderer)); }), { LudwigOnly: true })), I("yt-live-chat-text-input-field-renderer", ((t, e, { LudwigOnly: n }) => ({ functionName: t, function: e, ludwigOnly: n || !1, type: b.RunAfter }))("calculateLiveChatRichMessageInput_", (function(t) { var e; if (!(null == t ? void 0 : t.textSegments)) return t; for (const n of t.textSegments) if (null === (e = n.emojiId) || void 0 === e ? void 0 : e.startsWith("mogultv")) { const [, t] = n.emojiId.split("-"); delete n.emojiId, n.text = t; } return t }), { LudwigOnly: true })), i.on("emotes", (t => { if (!e$4()) return; const n = document.querySelector("yt-live-chat-item-list-renderer"); if (null == n ? void 0 : n.emojiManager) { if (n.emojiManager._mogulTvLoaded) return; n.emojiManager._mogulTvLoaded = !0, n.emojiManager.load([...t.values()]); } else console.warn("Cannot find chat list"); })); } function S(t) { return t ? t._mtvType ? t._mtvType : t.icon ? t.icon.iconType.toLowerCase() : t.customThumbnail ? "member" : "" : "" } async function M(t) { I("yt-live-chat-author-badge-renderer", B("computeType_", (t => S(t.liveChatAuthorBadgeRenderer)), { LudwigOnly: true })), I("yt-live-chat-author-chip", B("computeAuthorType_", (function(e) { var n, i; const a = this.$["author-name"]; if (a) { let e; const o = null === (n = this.parentElement) || void 0 === n ? void 0 : n.parentElement, r = null === (i = null == o ? void 0 : o.data) || void 0 === i ? void 0 : i.authorExternalChannelId; if (r) { const n = t.getUserInfo(r); (null == n ? void 0 : n.c) && (e = n.c); } e || (e = function(t) { const e = function(t) { let e = 0; if (0 === t.length) return 0; for (let n = 0; n < t.length; n++) e = (e << 5) - e + t.charCodeAt(n), e |= 0; return e }(t); return g[(e % g.length + g.length) % g.length] }(this.authorName.simpleText)), a.style.color = e; } return function(t) { if (!t) return ""; for (const e of t) { if (!e.liveChatAuthorBadgeRenderer) continue; const t = S(e.liveChatAuthorBadgeRenderer); if ("verified" !== t) return t } return "" }(e) }), { LudwigOnly: true })); } e$1("\n/* Make the masthead transparent unless we are hovering it */\nbody[data-mogul-theater-mode] #masthead-container {\n opacity: 0.1;\n transition: opacity .2s ease;\n}\n\nbody[data-mogul-theater-mode] #masthead-container:hover {\n opacity: 1;\n}\n\n\n@media screen and (min-width: 1014px) {\n /* Make chat fill screen vertically */\n body[data-mogul-theater-mode] #chat.ytd-watch-flexy {\n height: calc(100vh - 56px) !important;\n width: var(--ytd-watch-flexy-sidebar-width);\n position: absolute;\n top: 56px;\n right: 0;\n }\n\n body[data-mogul-theater-mode] #player-theater-container.ytd-watch-flexy {\n width: calc(100vw - var(--ytd-watch-flexy-sidebar-width) - var(--ytd-watch-flexy-scrollbar-width)) !important;\n max-width: calc(100vw - var(--ytd-watch-flexy-sidebar-width) - var(--ytd-watch-flexy-scrollbar-width)) !important;\n height: calc(100vh - 56px) !important;\n max-height: calc(100vh - 56px) !important;\n }\n}"); const R = null !== document.querySelector("yt-live-chat-app"), j = new e$2; if (R) { const t = new x(j), e = new T(t), n = new A(t); L = j, C(e, n, O = t), async function(t) { const e = await t.getLiveStorageValue("settings.chatBatching"); I("yt-timed-continuation", E("dataChanged_", (function() { e.value && (this.data.timeoutMs /= 3 * Math.random() + 2); }), { LudwigOnly: !0 })), I("yt-live-chat-renderer", E("preprocessActions_", (function(t) { const n = Object.getPrototypeOf(this.smoothedQueue_); for (const t in n) if (t.includes("emitSmoothedMessages")) { n[t] = function() { if (this.nextUpdateId_ = null, this.messageQueue_.length) { let i = 1e4; this.estimatedUpdateInterval_ && (i = this.estimatedUpdateInterval_ - Date.now() + this.lastUpdateTime_); const a = this.messageQueue_.length < i / 80 ? 1 : Math.ceil(this.messageQueue_.length / (i / 80)), o = this.messageQueue_.splice(0, a); if (this.callback && this.callback(o[0]), this.messageQueue_.length) { let o = 1; e.value || (1 === a ? (o = i / this.messageQueue_.length, o *= Math.random() + .5, o = Math.min(1e3, o), o = Math.max(80, o)) : o = 80), this.nextUpdateId_ = window.setTimeout(n[t].bind(this), o); } } }; break } return t }), { LudwigOnly: !0 })); }(L), M(O); } else !async function(t) { async function n() { const n = document.querySelector("ytd-watch-flexy"), i = (null == n ? void 0 : n.hasAttribute("theater")) || !1, a = (null == n ? void 0 : n.hasAttribute("fullscreen")) || !1, o = await t.getStorage("settings.theaterMode"), r = e$4(!1); return i && !a && o && r } let i = await n(); setInterval((async () => { await n() ? (document.body.setAttribute("data-mogul-theater-mode", ""), i || window.dispatchEvent(new Event("resize")), i = !0) : (i = !1, document.body.removeAttribute("data-mogul-theater-mode")); }), 250); }(j), async function(t) { if (!window.ytcfg) return; const e = { key: window.ytcfg.get("INNERTUBE_API_KEY"), authUser: window.ytcfg.get("SESSION_INDEX"), pageId: window.ytcfg.get("DELEGATED_SESSION_ID"), href: window.location.href, context: window.ytcfg.get("INNERTUBE_CONTEXT") }; n = await e$3(Object.assign(Object.assign({}, e), { cookies: v(document.cookie) })), i = await t.fetch("/auth/@me"), (!n.success || !i.meta.isSuccess || n.data.id !== (null === (a = i.body) || void 0 === a ? void 0 : a.sub)) && await t.fetch("/auth/login", e); var n, i, a; }(j), setInterval((() => { const t = document.querySelector("ytd-live-chat-frame iframe"); if (t && !t.src.includes("QXZRwEzaeHNfDqtD")) { const e = n(); t.src += `#QXZRwEzaeHNfDqtD=${encodeURIComponent(JSON.stringify(e))}`; } }), 1e3); var L, O;