Greasy Fork is available in English.

Youtubeᴾˡᵘˢ(油管)超级助手 - 视频下载 & 🚫去广告 & 布局优化,使用更舒服

这个脚本是一个增强器,用于提升您的YouTube观看体验!包含新功能和新布局。介绍:1.优化的视频详情页面界面。2.截图。3.深色/浅色主题切换。4.视频快进。等等。


安装此脚本?
作者推荐脚本

您可能也喜欢Online shopping assistant & Automatically query coupons & Save money

安装此脚本
// ==UserScript==
// @name        Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:zh-CN  Youtubeᴾˡᵘˢ(油管)超级助手 - 视频下载 & 🚫去广告 & 布局优化,使用更舒服
// @name:zh-TW  Youtubeᴾˡᵘˢ(油管)超級助手 - 視頻下載 & 🚫去廣告 & 布局優化,使用更舒服
// @name:ar     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:bg     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:cs     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:da     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:de     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:el     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:en     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:eo     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:es     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:es-419 Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:fi     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:fr     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:fr-CA  Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:he     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:hr     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:hu     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:id     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!))
// @name:it     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ja     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ka     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ko     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:nb     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:nl     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:pl     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:pt-BR  Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ro     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ru     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:sv     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:th     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:tr     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:uk     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:ug     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @name:vi     Youtubeᴾˡᵘˢ Super Assistant(Video Downloader & 🚫 No ads & New Layout For YT!)
// @description       The script is an Enhancer for Youtube to improve your watching experience!Contains features & new layout. Introduction: 1.Optimized Video Detail Page Interface. 2.Screenshot. 3.Dark/Light Theme Switch. 4.Video Fast Forward. etc.
// @description:zh-CN 这个脚本是一个增强器,用于提升您的YouTube观看体验!包含新功能和新布局。介绍:1.优化的视频详情页面界面。2.截图。3.深色/浅色主题切换。4.视频快进。等等。
// @description:zh-TW 這個腳本是一個增強器,用於提升您的YouTube觀看體驗!包含新功能和新佈局。介紹:1.優化的影片詳細頁面介面。2.截圖。3.深色/淺色主題切換。4.影片快轉。等等。
// @description:ar    البرنامج هو معزز لتحسين تجربة المشاهدة على يوتيوب! يحتوي على ميزات وتصميم جديد. المقدمة: 1. واجهة صفحة تفاصيل الفيديو المحسنة. 2. لقطة الشاشة. 3. التبديل بين الوضع الداكن/الفاتح. 4. تسريع الفيديو. إلخ.
// @description:bg    Скриптът е усилвател за подобряване на вашето изживяване в YouTube! Съдържа функции и нов дизайн. Въведение: 1. Оптимизирана страница с детайли за видео. 2. Снимка на екрана. 3. Превключване между тъмна/светла тема. 4. Бързо превъртане на видеото. и др.
// @description:cs    Skript je vylepšovač pro zlepšení vaší sledovací zkušenosti na YouTube! Obsahuje funkce a nový vzhled. Úvod: 1. Optimalizované rozhraní stránky s podrobnostmi o videu. 2. Snímek obrazovky. 3. Přepínač tmavého/světlého režimu. 4. Rychlé přetáčení videa. atd.
// @description:da    Scriptet er en forbedrer til at forbedre din seeroplevelse på YouTube! Indeholder funktioner og nyt layout. Introduktion: 1. Optimeret video detajtside interface. 2. Skærmbillede. 3. Mørk/lys tema skift. 4. Hurtig fremspoling af video. osv.
// @description:de    Das Skript ist ein Enhancer, um dein YouTube-Erlebnis zu verbessern! Es enthält Funktionen und ein neues Layout. Einführung: 1. Optimierte Video-Detail-Seitenoberfläche. 2. Screenshot. 3. Dunkel-/Helle-Themen-Schalter. 4. Video-Schnellvorlauf. usw.
// @description:el    Το σενάριο είναι ένας ενισχυτής για να βελτιώσετε την εμπειρία παρακολούθησης στο YouTube! Περιλαμβάνει δυνατότητες και νέο σχέδιο. Εισαγωγή: 1. Βελτιστοποιημένο interface σελίδας λεπτομερειών βίντεο. 2. Στιγμιότυπο οθόνης. 3. Εναλλαγή σκοτεινού/φωτεινού θέματος. 4. Γρήγορη προώθηση βίντεο. κ.ά.
// @description:en    The script is an Enhancer for YouTube to improve your watching experience! Contains features & new layout. Introduction: 1. Optimized Video Detail Page Interface. 2. Screenshot. 3. Dark/Light Theme Switch. 4. Video Fast Forward. etc.
// @description:eo    La skripto estas plibonigilo por YouTube por plibonigi vian spekton. Ĝi enhavas funkciojn kaj novan aranĝon. Enkonduko: 1. Optimumigita Videodetalpa Paĝa Interfaco. 2. Ekranbildo. 3. Ŝanĝo de Malluma/Luma Temoj. 4. Rapida Antaŭenŝovo de Video. ktp.
// @description:es    ¡El script es un mejorador para YouTube para mejorar tu experiencia de visualización! Contiene características y un diseño nuevo. Introducción: 1. Interfaz optimizada de la página de detalles del video. 2. Captura de pantalla. 3. Cambio de tema oscuro/claro. 4. Avance rápido de video. etc.
// @description:fi    Skripti on parannus, joka parantaa YouTube-kokemustasi! Sisältää ominaisuuksia ja uuden ulkoasun. Johdanto: 1. Optimoitu videon yksityiskohdasivun käyttöliittymä. 2. Kuvakaappaus. 3. Tumma/vaalea teema-vaihto. 4. Videon nopea eteenpäin siirto. jne.
// @description:fr    Le script est un amplificateur pour améliorer votre expérience de visionnage sur YouTube ! Il contient des fonctionnalités et une nouvelle mise en page. Introduction : 1. Interface optimisée de la page de détails de la vidéo. 2. Capture d'écran. 3. Commutateur de thème sombre/claire. 4. Avance rapide de la vidéo. etc.
// @description:fr-CA Le script est un amplificateur pour améliorer votre expérience de visionnage sur YouTube ! Il comprend des fonctionnalités et une nouvelle interface. Introduction : 1. Interface optimisée de la page de détails de la vidéo. 2. Capture d'écran. 3. Changement de thème sombre/clair. 4. Avance rapide de vidéo. etc.
// @description:he    הסקריפט הוא משפר לשיפור חווית הצפייה שלך ב-YouTube! מכיל תכונות ועיצוב חדש. הצגה: 1. ממשק מעודכן לדף פרטי וידאו. 2. צילום מסך. 3. מתחלף נושא כהה/בהיר. 4. קפיצה קדימה של וידאו. וכו'.
// @description:hr    Skripta je pojačivač za poboljšanje vašeg iskustva gledanja na YouTubeu! Sadrži značajke i novi izgled. Uvod: 1. Optimizirani sučelje stranice s detaljima videa. 2. Slikovni prikaz. 3. Prebacivanje između tamne/svijetle teme. 4. Brzo premotavanje videa. itd.
// @description:hu    A szkript egy enhancer a YouTube-élményed javítására! Tartalmaz funkciókat és új elrendezést. Bevezetés: 1. Optimalizált videó részletes oldal elrendezés. 2. Képernyőfotó. 3. Sötét/fényes téma váltás. 4. Videó gyors előretekerés. stb.
// @description:id    Skriptnya adalah Enhancer untuk meningkatkan pengalaman menonton YouTube Anda! Berisi fitur dan tata letak baru. Pengenalan: 1. Antarmuka Halaman Detail Video yang Dioptimalkan. 2. Tangkapan layar. 3. Tombol Switch Tema Gelap/Terang. 4. Pencarian Cepat Video. dll.
// @description:it    Lo script è un miglioratore per migliorare la tua esperienza di visione su YouTube! Contiene funzionalità e un nuovo layout. Introduzione: 1. Interfaccia della pagina dei dettagli video ottimizzata. 2. Screenshot. 3. Switch tra tema scuro/chiaro. 4. Avanzamento rapido del video. ecc.
// @description:ja    このスクリプトは、YouTubeの視聴体験を向上させるためのエンハンサーです!新しいレイアウトと機能が含まれています。紹介: 1. 最適化された動画詳細ページインターフェース。 2. スクリーンショット。 3. ダーク/ライトテーマの切り替え。 4. 動画の早送り。など。
// @description:ka    ეს სკრიპტი არის YouTube-ის დამხმარე პროგრამა თქვენი ყურების გამოცდილების გასაუმჯობესებლად! შეიცავს ფუნქციებს და ახალ დიზაინს. შესავალი: 1. ოპტიმიზებული ვიდეო დეტალების გვერდის ინტერფეისი. 2. ეკრანული სურათი. 3. ბნელ/ღია თემის გადართვა. 4. ვიდეოს სწრაფი გადახვევა. და სხვ.
// @description:ko    이 스크립트는 YouTube 시청 경험을 개선하는 향상기입니다! 기능과 새로운 레이아웃을 포함합니다. 소개: 1. 최적화된 비디오 세부 페이지 인터페이스. 2. 스크린샷. 3. 어두운/밝은 테마 전환. 4. 비디오 빠른 되감기. 등.
// @description:nb    Skriptet er en forsterker for å forbedre din YouTube-opplevelse! Inneholder funksjoner og nytt layout. Introduksjon: 1. Optimalisert videodetaljside-grensesnitt. 2. Skjermbilde. 3. Mørk/lys tema-bytte. 4. Video rask fremover. osv.
// @description:nl    Het script is een enhancer om je kijkervaring op YouTube te verbeteren! Bevat functies en een nieuwe lay-out. Inleiding: 1. Geoptimaliseerde interface voor videodetailpagina. 2. Screenshot. 3. Donker/licht thema wisselen. 4. Video snel vooruit spoelen. enz.
// @description:pl    Skrypt to wzmacniacz poprawiający twoje doświadczenie oglądania na YouTube! Zawiera funkcje i nowy układ. Wprowadzenie: 1. Optymalizowany interfejs strony szczegółów wideo. 2. Zrzut ekranu. 3. Przełącznik motywu ciemnego/jasnego. 4. Szybkie przewijanie wideo. itd.
// @description:pt-BR O script é um aprimorador para melhorar sua experiência de visualização no YouTube! Contém recursos e um novo layout. Introdução: 1. Interface otimizada da página de detalhes do vídeo. 2. Captura de tela. 3. Alternância entre tema escuro/ claro. 4. Avanço rápido de vídeo. etc.
// @description:ro    Scriptul este un îmbunătățitor pentru a-ți îmbunătăți experiența de vizionare pe YouTube! Conține funcții și un nou design. Introducere: 1. Interfața optimizată a paginii detaliilor video. 2. Captură de ecran. 3. Schimbător de temă închis/deschis. 4. Derulare rapidă video. etc.
// @description:ru    Скрипт — это усилитель для улучшения вашего опыта просмотра на YouTube! Содержит функции и новый макет. Введение: 1. Оптимизированный интерфейс страницы с деталями видео. 2. Скриншот. 3. Переключатель темной/светлой темы. 4. Быстрое перематывание видео. и т. д.
// @description:sv    Scriptet är en förstärkare för att förbättra din tittarupplevelse på YouTube! Innehåller funktioner och en ny layout. Introduktion: 1. Optimerat video detaljsida gränssnitt. 2. Skärmdump. 3. Växla mellan mörkt/ljus tema. 4. Snabbspola video. osv.
// @description:th    สคริปต์นี้คือเครื่องมือเสริมเพื่อปรับปรุงประสบการณ์การดูของคุณบน YouTube! มีฟีเจอร์และเลย์เอาต์ใหม่ๆ แนะนำ: 1. อินเตอร์เฟซหน้ารายละเอียดวิดีโอที่ได้รับการปรับแต่ง. 2. ถ่ายภาพหน้าจอ. 3. สลับโหมดมืด/สว่าง. 4. การเลื่อนวิดีโออย่างรวดเร็ว. เป็นต้น.
// @description:tr    Bu script, YouTube izleme deneyiminizi geliştirmek için bir Enhancer'dır! Özellikler ve yeni bir tasarım içerir. Tanıtım: 1. Optimize edilmiş Video Detay Sayfası Arayüzü. 2. Ekran Görüntüsü. 3. Karanlık/Aydınlık Tema Geçişi. 4. Video Hızlı İleri Sarma. vb.
// @description:uk    Скрипт — це посилювач для покращення вашого досвіду перегляду на YouTube! Включає функції та новий макет. Вступ: 1. Оптимізований інтерфейс сторінки деталей відео. 2. Знімок екрана. 3. Перемикач темної/світлої теми. 4. Швидке перемотування відео. тощо.
// @description:ug    بۇ سكرىپت YouTube كۆرۈش تەجرىبەڭىزنى ياخشىلايدىغان كۈچەيتكۈچ! خۇسۇسىيەتلەر ۋە يېڭى تۈزۈلۈشنى ئۆز ئىچىگە ئالىدۇ. كىرۈش: 1. ۋىدىئو تەپسىلاتلىرى بەت ئىنتېرەيسىنى مۇۋاپىقلاش. 2. سكرىن رەسىمى. 3. قارا/ئاق تېما ئالماشتۇرۇش. 4. ۋىدىئونى تېز ئىلگىرى سۈرۈش. قاتارلىقلار.
// @description:vi    Kịch bản là một công cụ tăng cường để cải thiện trải nghiệm xem YouTube của bạn! Bao gồm các tính năng và giao diện mới. Giới thiệu: 1. Giao diện trang chi tiết video tối ưu. 2. Chụp màn hình. 3. Chuyển đổi giữa chủ đề tối/ sáng. 4. Tua nhanh video. v.v.
// @namespace FunnyMonkey_NameScope
// @version   2.0.4
// @author    FunnyMonkey
// @icon      
// @include   https://www.youtube.com
// @include   *://*.youtube.com/**
// @exclude   *://accounts.youtube.com/*
// @exclude   *://www.youtube.com/live_chat_replay*
// @exclude   *://www.youtube.com/persist_identity*
// @license   MIT
// @run-at    document-start
// @grant     GM_registerMenuCommand
// @grant     GM_openInTab
// @grant     GM.openInTab
// @grant     GM_addStyle
// @grant     GM_setValue
// @grant     GM_getValue
// @grant     GM_xmlhttpRequest
// @grant     GM_download
// @grant     GM_setClipboard
// @grant     GM_info
// @grant     unsafeWindow
// @grant     GM_cookie
// ==/UserScript==
(function () {
'use strict';
/*!
* Copyright (c) 2024 - 2025, FunnyMonkey. All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
*
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
var css_248z$1 = "@keyframes relatedElementProvided{0%{background-position-x:3px}to{background-position-x:4px}}html[tabview-loaded=icp] #related.ytd-watch-flexy{animation:relatedElementProvided 1ms linear 0s 1 normal forwards}html[tabview-loaded=icp] #right-tabs #related.ytd-watch-flexy,html[tabview-loaded=icp] #right-tabs ytd-expander#expander,html[tabview-loaded=icp] [hidden] #related.ytd-watch-flexy,html[tabview-loaded=icp] [hidden] ytd-expander#expander,html[tabview-loaded=icp] ytd-comments ytd-expander#expander{animation:initial}#secondary.ytd-watch-flexy{position:relative}#secondary-inner.style-scope.ytd-watch-flexy{height:100%}secondary-wrapper{border:0;box-sizing:border-box;contain:strict;flex-wrap:nowrap;height:100%;left:0;max-height:calc(100vh - var(--ytd-toolbar-height, 56px));padding:0;padding-bottom:var(--ytd-margin-6x);padding-right:var(--ytd-margin-6x);padding-top:var(--ytd-margin-6x);position:absolute;right:0;top:0}#right-tabs,secondary-wrapper{display:flex;flex-direction:column;margin:0}#right-tabs{flex-grow:1;padding:0;position:relative}[tyt-tab=\"\"] #right-tabs{flex-grow:0}[tyt-tab=\"\"] #right-tabs .tab-content{border:0}#right-tabs .tab-content{flex-grow:1}ytd-watch-flexy[hide-default-text-inline-expander] #primary.style-scope.ytd-watch-flexy ytd-text-inline-expander{display:none}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden{--comment-pre-load-sizing:90px;border:0;contain:strict;display:block!important;height:var(--comment-pre-load-sizing)!important;left:2px;margin:0;overflow:hidden;padding:0;pointer-events:none!important;position:fixed!important;top:2px;visibility:collapse;width:var(--comment-pre-load-sizing)!important;z-index:-1}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>*{display:none!important}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections{border:0;contain:strict;display:block!important;height:var(--comment-pre-load-sizing);margin:0;overflow:hidden;padding:0;width:var(--comment-pre-load-sizing)}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>*{display:none!important}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>#contents{border:0;contain:strict;display:flex!important;flex-direction:row;gap:60px;height:var(--comment-pre-load-sizing);margin:0;overflow:hidden;padding:0;width:var(--comment-pre-load-sizing)}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>#contents>*{border:0;box-sizing:content-box;contain:strict;display:block!important;height:var(--comment-pre-load-sizing);margin:calc(var(--comment-pre-load-sizing)*2)!important;overflow:hidden;padding:0;visibility:collapse!important;width:var(--comment-pre-load-sizing)}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>#contents>:empty{box-sizing:content-box;contain:strict;display:none!important;height:0;margin:0!important;overflow:hidden;visibility:collapse!important;width:0}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>#contents>ytd-continuation-item-renderer{box-sizing:initial;contain:strict;display:block!important;height:1px;margin:0!important;overflow:initial;visibility:collapse!important;width:1px}ytd-watch-flexy:not([keep-comments-scroller]) #tab-comments.tab-content-hidden ytd-comments#comments>ytd-item-section-renderer#sections>#contents>*>*{box-sizing:content-box;contain:strict;display:none!important;height:0;margin:0!important;overflow:hidden;visibility:collapse!important;width:0}#right-tabs #material-tabs{border:1px solid var(--ytd-searchbox-legacy-border-color);display:flex;overflow:hidden;padding:0;position:relative}[tyt-tab] #right-tabs #material-tabs{border-radius:var(--tyt-rounded-a1) var(--tyt-rounded-a1) var(--tyt-rounded-a1) var(--tyt-rounded-a1)}[tyt-tab^=\"#\"] #right-tabs #material-tabs{border-radius:var(--tyt-rounded-a1) var(--tyt-rounded-a1) 0 0}ytd-watch-flexy[flexy]:not([is-two-columns_]) #right-tabs #material-tabs{outline:0}#right-tabs #material-tabs a.tab-btn[tyt-tab-content]>*{pointer-events:none}#right-tabs #material-tabs a.tab-btn[tyt-tab-content]>.font-size-right{display:none;pointer-events:auto}ytd-watch-flexy #right-tabs .tab-content{border:1px solid var(--ytd-searchbox-legacy-border-color);border-radius:0 0 var(--tyt-rounded-a1) var(--tyt-rounded-a1);border-top:0;box-sizing:border-box;display:block;display:flex;flex-direction:row;overflow:hidden;padding:0;position:relative;top:0}ytd-watch-flexy:not([is-two-columns_]) #right-tabs .tab-content{height:100%}ytd-watch-flexy #right-tabs .tab-content-cld{--tab-content-padding:var(--ytd-margin-4x);box-sizing:border-box;contain:layout paint;display:block;overflow:auto;padding:var(--tab-content-padding);position:relative;width:100%}#right-tabs,.tab-content,.tab-content-cld{animation:none;transition:none}ytd-watch-flexy[is-two-columns_] #right-tabs .tab-content-cld{contain:size layout paint style;height:100%;position:absolute;width:100%}ytd-watch-flexy #right-tabs .tab-content-cld.tab-content-hidden{contain:size layout paint style;display:none;width:100%}@supports (color:var(--tabview-tab-btn-define )){ytd-watch-flexy #right-tabs .tab-btn{background:var(--yt-spec-general-background-a)}html{--tyt-tab-btn-flex-grow:1;--tyt-tab-btn-flex-basis:0%;--tyt-tab-bar-color-1-def:#ff4533;--tyt-tab-bar-color-2-def:var(--yt-brand-light-red);--tyt-tab-bar-color-1:var(--main-color,var(--tyt-tab-bar-color-1-def));--tyt-tab-bar-color-2:var(--main-color,var(--tyt-tab-bar-color-2-def))}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]{--tyt-tab-btn-color:var(--yt-spec-text-secondary);background-color:var(--ytd-searchbox-legacy-button-color);border:0;border-bottom:4px solid transparent;color:var(--tyt-tab-btn-color);cursor:pointer;display:inline-block;flex-basis:0%;flex-basis:var(--tyt-tab-btn-flex-basis);flex-grow:1;flex-grow:var(--tyt-tab-btn-flex-grow);flex-shrink:1;font-size:12px;font-weight:500;line-height:18px;overflow:hidden;padding:14px 8px 10px;position:relative;text-align:center;text-decoration:none;text-overflow:clip;text-transform:uppercase;text-transform:var(--yt-button-text-transform,inherit);transition:border .2s linear .1s;white-space:nowrap}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]>svg{fill:var(--iron-icon-fill-color,currentcolor);stroke:var(--iron-icon-stroke-color,none);color:var(--yt-button-color,inherit);height:18px;margin-right:0;opacity:.5;padding-right:0;vertical-align:bottom}ytd-watch-flexy #right-tabs .tab-btn{--tabview-btn-txt-ml:8px}ytd-watch-flexy[tyt-comment-disabled] #right-tabs .tab-btn[tyt-tab-content=\"#tab-comments\"]{--tabview-btn-txt-ml:0px}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]>svg+span{margin-left:var(--tabview-btn-txt-ml)}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content] svg{pointer-events:none}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content].active{--tyt-tab-btn-color:var(--yt-spec-text-primary);background-color:var(--ytd-searchbox-legacy-button-focus-color);border-bottom-color:var(--tyt-tab-bar-color-1);border-bottom:2px solid var(--tyt-tab-bar-color-2);font-weight:500;outline:0}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content].active svg{opacity:.9}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]:not(.active):hover{--tyt-tab-btn-color:var(--yt-spec-text-primary);background-color:var(--ytd-searchbox-legacy-button-hover-color)}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]:not(.active):hover svg{opacity:.9}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content]{user-select:none!important}ytd-watch-flexy #right-tabs .tab-btn[tyt-tab-content].tab-btn-hidden{display:none}ytd-watch-flexy[tyt-comment-disabled] #right-tabs .tab-btn[tyt-tab-content=\"#tab-comments\"],ytd-watch-flexy[tyt-comment-disabled] #right-tabs .tab-btn[tyt-tab-content=\"#tab-comments\"]:hover{--tyt-tab-btn-color:var(--yt-spec-icon-disabled)}ytd-watch-flexy[tyt-comment-disabled] #right-tabs .tab-btn[tyt-tab-content=\"#tab-comments\"] span#tyt-cm-count:empty{display:none}ytd-watch-flexy #right-tabs .tab-btn span#tyt-cm-count:empty:after{color:currentColor;display:inline-block;font-size:inherit;text-align:left;transform:scaleX(.8);width:4em}}@supports (color:var(--tyt-cm-count-define )){ytd-watch-flexy{--tyt-x-loading-content-letter-spacing:2px}html{--tabview-text-loading:\"Loading\";--tabview-text-fetching:\"Fetching\";--tabview-panel-loading:var(--tabview-text-loading)}html:lang(ja){--tabview-text-loading:\"読み込み中\";--tabview-text-fetching:\"フェッチ..\"}html:lang(ko){--tabview-text-loading:\"로딩..\";--tabview-text-fetching:\"가져오기..\"}html:lang(zh-Hant){--tabview-text-loading:\"載入中\";--tabview-text-fetching:\"擷取中\"}html:lang(zh-Hans){--tabview-text-loading:\"加载中\";--tabview-text-fetching:\"抓取中\"}html:lang(ru){--tabview-text-loading:\"Загрузка\";--tabview-text-fetching:\"Получение\"}ytd-watch-flexy #right-tabs .tab-btn span#tyt-cm-count:empty:after{content:var(--tabview-text-loading);letter-spacing:var(--tyt-x-loading-content-letter-spacing)}}@supports (color:var(--tabview-font-size-btn-define )){.font-size-right{align-content:space-evenly;bottom:0;display:inline-flex;flex-direction:column;justify-content:space-evenly;padding:4px 0;pointer-events:none;position:absolute;right:0;top:0;width:16px}html body ytd-watch-flexy.style-scope .font-size-btn{user-select:none!important}.font-size-btn{--tyt-font-size-btn-display:none;background-color:var(--yt-spec-badge-chip-background);box-sizing:border-box;color:var(--yt-spec-text-secondary);cursor:pointer;display:var(--tyt-font-size-btn-display,none);font-family:Menlo,Lucida Console,Monaco,Consolas,monospace;font-weight:900;height:12px;line-height:100%;margin:0;padding:0;pointer-events:all;position:relative;transform-origin:left top;transition:background-color 90ms linear,color 90ms linear;width:12px}.font-size-btn:hover{background-color:var(--yt-spec-text-primary);color:var(--yt-spec-general-background-a)}@supports (zoom:0.5){.tab-btn .font-size-btn{--tyt-font-size-btn-display:none}.tab-btn.active:hover .font-size-btn{--tyt-font-size-btn-display:inline-block}}}body ytd-watch-flexy:not([is-two-columns_]) #columns.ytd-watch-flexy{flex-direction:column}body ytd-watch-flexy:not([is-two-columns_]) #secondary.ytd-watch-flexy{box-sizing:border-box;display:block;width:100%}body ytd-watch-flexy:not([is-two-columns_]) #secondary.ytd-watch-flexy secondary-wrapper{contain:content;height:auto;padding-left:var(--ytd-margin-6x)}body ytd-watch-flexy:not([is-two-columns_]) #secondary.ytd-watch-flexy secondary-wrapper #right-tabs{overflow:auto}[tyt-chat=\"+\"] secondary-wrapper>[tyt-chat-container]{display:flex;flex-direction:column;flex-grow:1;flex-shrink:0}[tyt-chat=\"+\"] secondary-wrapper>[tyt-chat-container]>#chat{flex-grow:1}ytd-watch-flexy[is-two-columns_]:not([theater]) #columns.style-scope.ytd-watch-flexy{min-height:calc(100vh - var(--ytd-toolbar-height, 56px))}ytd-watch-flexy[is-two-columns_] ytd-live-chat-frame#chat{height:auto!important;min-height:auto!important}ytd-watch-flexy[tyt-tab^=\"#\"]:not([is-two-columns_]):not([tyt-chat=\"+\"]) #right-tabs{min-height:var(--ytd-watch-flexy-chat-max-height)}body ytd-watch-flexy:not([is-two-columns_]) #chat.ytd-watch-flexy{margin-top:0}body ytd-watch-flexy:not([is-two-columns_]) ytd-watch-metadata.ytd-watch-flexy{margin-bottom:0}ytd-watch-metadata.ytd-watch-flexy ytd-metadata-row-container-renderer{display:none}#tab-info [show-expand-button] #expand-sizer.ytd-text-inline-expander{visibility:initial}#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>#left-arrow-container.ytd-video-description-infocards-section-renderer>#left-arrow,#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>#right-arrow-container.ytd-video-description-infocards-section-renderer>#right-arrow{border:6px solid transparent;opacity:.65}#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>#left-arrow-container.ytd-video-description-infocards-section-renderer>#left-arrow:hover,#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>#right-arrow-container.ytd-video-description-infocards-section-renderer>#right-arrow:hover{opacity:1}#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>div#left-arrow-container:before{background:transparent;content:\"\";display:block;height:40px;left:-20px;position:absolute;top:0;width:40px;z-index:-1}#tab-info #social-links.style-scope.ytd-video-description-infocards-section-renderer>div#right-arrow-container:before{background:transparent;content:\"\";display:block;height:40px;position:absolute;right:-20px;top:0;width:40px;z-index:-1}body ytd-watch-flexy[is-two-columns_][tyt-egm-panel_] #columns.style-scope.ytd-watch-flexy #panels.style-scope.ytd-watch-flexy{display:flex;flex-direction:column;flex-grow:1;flex-shrink:0}body ytd-watch-flexy[is-two-columns_][tyt-egm-panel_] #columns.style-scope.ytd-watch-flexy #panels.style-scope.ytd-watch-flexy ytd-engagement-panel-section-list-renderer[target-id][visibility=ENGAGEMENT_PANEL_VISIBILITY_EXPANDED]{display:flex;flex-direction:column;flex-grow:1;flex-shrink:0;height:auto;max-height:none;min-height:auto}secondary-wrapper [visibility=ENGAGEMENT_PANEL_VISIBILITY_EXPANDED] #body.ytd-transcript-renderer:not(:empty),secondary-wrapper [visibility=ENGAGEMENT_PANEL_VISIBILITY_EXPANDED] #content.ytd-transcript-renderer:not(:empty),secondary-wrapper [visibility=ENGAGEMENT_PANEL_VISIBILITY_EXPANDED] ytd-transcript-renderer:not(:empty){flex-grow:1;height:auto;max-height:none;min-height:auto}secondary-wrapper #content.ytd-engagement-panel-section-list-renderer{position:relative}secondary-wrapper #content.ytd-engagement-panel-section-list-renderer>[panel-target-id]:only-child{contain:style size}secondary-wrapper #content.ytd-engagement-panel-section-list-renderer ytd-transcript-segment-list-renderer.ytd-transcript-search-panel-renderer{contain:strict;flex-grow:1}secondary-wrapper #content.ytd-engagement-panel-section-list-renderer ytd-transcript-segment-renderer.style-scope.ytd-transcript-segment-list-renderer,secondary-wrapper #content.ytd-engagement-panel-section-list-renderer ytd-transcript-segment-renderer.style-scope.ytd-transcript-segment-list-renderer>.segment{contain:layout paint style}body ytd-watch-flexy[theater] #secondary.ytd-watch-flexy{margin-top:var(--ytd-margin-3x);padding-top:0}body ytd-watch-flexy[theater] secondary-wrapper{margin-top:0;padding-top:0}body ytd-watch-flexy[theater] #chat.ytd-watch-flexy{margin-bottom:var(--ytd-margin-2x)}#tab-comments ytd-comments#comments [field-of-cm-count]{margin-top:0}#tab-info>ytd-expandable-video-description-body-renderer{margin-bottom:var(--ytd-margin-3x)}#tab-info [class]:last-child{margin-bottom:0;padding-bottom:0}#tab-info ytd-rich-metadata-row-renderer ytd-rich-metadata-renderer{max-width:none}ytd-watch-flexy[is-two-columns_] secondary-wrapper #chat.ytd-watch-flexy{margin-bottom:var(--ytd-margin-3x)}ytd-watch-flexy[tyt-tab] tp-yt-paper-tooltip{contain:content;white-space:nowrap}ytd-watch-info-text tp-yt-paper-tooltip.style-scope.ytd-watch-info-text{margin-bottom:-300px;margin-top:-96px}[hide-default-text-inline-expander] #bottom-row #description.ytd-watch-metadata{font-size:1.2rem;line-height:1.8rem}[hide-default-text-inline-expander] #bottom-row #description.ytd-watch-metadata yt-animated-rolling-number{font-size:inherit}[hide-default-text-inline-expander] #bottom-row #description.ytd-watch-metadata #info-container.style-scope.ytd-watch-info-text{align-items:center}ytd-watch-flexy[hide-default-text-inline-expander]{--tyt-bottom-watch-metadata-margin:6px}[hide-default-text-inline-expander] #bottom-row #description.ytd-watch-metadata>#description-inner.ytd-watch-metadata{margin:6px 12px}[hide-default-text-inline-expander] ytd-watch-metadata[title-headline-xs] h1.ytd-watch-metadata{font-size:1.8rem}ytd-watch-flexy[is-two-columns_][hide-default-text-inline-expander] #below.style-scope.ytd-watch-flexy ytd-merch-shelf-renderer{border:0;margin:0;padding:0}ytd-watch-flexy[is-two-columns_][hide-default-text-inline-expander] #below.style-scope.ytd-watch-flexy ytd-watch-metadata.ytd-watch-flexy{margin-bottom:6px}#tab-info yt-video-attribute-view-model .yt-video-attribute-view-model--horizontal .yt-video-attribute-view-model__link-container .yt-video-attribute-view-model__hero-section{flex-shrink:0}#tab-info yt-video-attribute-view-model .yt-video-attribute-view-model__overflow-menu{background:var(--yt-emoji-picker-category-background-color);border-radius:99px}#tab-info yt-video-attribute-view-model .yt-video-attribute-view-model--image-square.yt-video-attribute-view-model--image-large .yt-video-attribute-view-model__hero-section{max-height:128px}#tab-info yt-video-attribute-view-model .yt-video-attribute-view-model--image-large .yt-video-attribute-view-model__hero-section{max-width:128px}#tab-info ytd-reel-shelf-renderer #items.yt-horizontal-list-renderer ytd-reel-item-renderer.yt-horizontal-list-renderer{max-width:142px}ytd-watch-info-text#ytd-watch-info-text.style-scope.ytd-watch-metadata #date-text.style-scope.ytd-watch-info-text,ytd-watch-info-text#ytd-watch-info-text.style-scope.ytd-watch-metadata #view-count.style-scope.ytd-watch-info-text{align-items:center}ytd-watch-info-text:not([detailed]) #info.ytd-watch-info-text a.yt-simple-endpoint.yt-formatted-string{pointer-events:none}body ytd-app>ytd-popup-container>tp-yt-iron-dropdown>#contentWrapper>[slot=dropdown-content]{backdrop-filter:none}#tab-info [tyt-clone-refresh-count]{overflow:visible!important}#tab-info #items.ytd-horizontal-card-list-renderer yt-video-attribute-view-model.ytd-horizontal-card-list-renderer{contain:layout}#tab-info #thumbnail-container.ytd-structured-description-channel-lockup-renderer,#tab-info ytd-media-lockup-renderer[is-compact] #thumbnail-container.ytd-media-lockup-renderer{flex-shrink:0}secondary-wrapper ytd-donation-unavailable-renderer{--ytd-margin-6x:var(--ytd-margin-2x);--ytd-margin-5x:var(--ytd-margin-2x);--ytd-margin-4x:var(--ytd-margin-2x);--ytd-margin-3x:var(--ytd-margin-2x)}[tyt-no-less-btn] #less{display:none}.tyt-metadata-hover-resized #analytics-button,.tyt-metadata-hover-resized #purchase-button,.tyt-metadata-hover-resized #sponsor-button,.tyt-metadata-hover-resized #subscribe-button{display:none!important}.tyt-metadata-hover #upload-info{flex-basis:100vw;flex-shrink:0;max-width:max-content;min-width:max-content}#tab-info ytd-structured-description-playlist-lockup-renderer[collections] #playlist-thumbnail.style-scope.ytd-structured-description-playlist-lockup-renderer{max-width:100%}#tab-info ytd-structured-description-playlist-lockup-renderer[collections] #lockup-container.ytd-structured-description-playlist-lockup-renderer{padding:1px}#tab-info ytd-structured-description-playlist-lockup-renderer[collections] #thumbnail.ytd-structured-description-playlist-lockup-renderer{outline:1px solid hsla(0,0%,50%,.5)}ytd-live-chat-frame#chat[collapsed] ytd-message-renderer~#show-hide-button.ytd-live-chat-frame>ytd-toggle-button-renderer.ytd-live-chat-frame{padding:0}.tyt-info-invisible{display:none}[tyt-playlist-expanded] secondary-wrapper>ytd-playlist-panel-renderer#playlist{flex-grow:1;flex-shrink:1;max-height:unset!important;overflow:auto}[tyt-playlist-expanded] secondary-wrapper>ytd-playlist-panel-renderer#playlist>#container{max-height:unset!important}secondary-wrapper ytd-playlist-panel-renderer{--ytd-margin-6x:var(--ytd-margin-3x)}ytd-watch-flexy[theater] ytd-playlist-panel-renderer[collapsible][collapsed] .header.ytd-playlist-panel-renderer{padding:6px 8px}ytd-watch-flexy[theater] #playlist.ytd-watch-flexy{margin-bottom:var(--ytd-margin-2x)}ytd-watch-flexy[theater] #right-tabs .tab-btn[tyt-tab-content]{border-bottom:0 solid transparent;padding:8px 4px 6px}ytd-watch-flexy{--tyt-bottom-watch-metadata-margin:12px}ytd-watch-flexy[rounded-info-panel],ytd-watch-flexy[rounded-player-large]{--tyt-rounded-a1:${VAL_ROUNDED_A1}px}#bottom-row.style-scope.ytd-watch-metadata .item.ytd-watch-metadata{margin-right:var(--tyt-bottom-watch-metadata-margin,12px);margin-top:var(--tyt-bottom-watch-metadata-margin,12px)}#cinematics{contain:layout style size}";
const VAL_ROUNDED_A1 = 12;
const styles = {
main: css_248z$1.replace("${VAL_ROUNDED_A1}", VAL_ROUNDED_A1)
};
/*!
* table function
* MIT, https://github.com/tabview-youtube/Tabview-Youtube
* @param {*} communicationKey
* Optimize project structure to make it more reliable
*/
const executionScript = (communicationKey) => {
if (typeof trustedTypes !== "undefined" && trustedTypes.defaultPolicy === null) {
let s = (s2) => s2;
trustedTypes.createPolicy("default", {
createHTML: s,
createScriptURL: s,
createScript: s
});
}
const defaultPolicy = typeof trustedTypes !== "undefined" && trustedTypes.defaultPolicy || { createHTML: (s) => s };
function createHTML(s) {
return defaultPolicy.createHTML(s);
}
let trustHTMLErr = null;
try {
document.createElement("div").innerHTML = createHTML("1");
} catch (e) {
trustHTMLErr = e;
}
if (trustHTMLErr) {
trustHTMLErr();
}
const setTimeout_ = setTimeout.bind(window);
try {
let getWord = function(tag) {
return langWords[pageLang][tag] || langWords["en"][tag] || "";
}, getTabsHTML = function() {
const sTabBtnVideos = `${svgElm(
16,
16,
90,
90,
svgVideos
)}<span>${getWord("videos")}</span>`;
const sTabBtnInfo = `${svgElm(16, 16, 60, 60, svgInfo)}<span>${getWord(
"info"
)}</span>`;
const sTabBtnPlayList = `${svgElm(
16,
16,
20,
20,
svgPlayList
)}<span>${getWord("playlist")}</span>`;
let str1 = `
<paper-ripple class="style-scope yt-icon-button">
<div id="background" class="style-scope paper-ripple" style="opacity:0;"></div>
<div id="waves" class="style-scope paper-ripple"></div>
</paper-ripple>
`;
let str_fbtns = `
<div class="font-size-right">
<div class="font-size-btn font-size-plus" tyt-di="8rdLQ">
<svg width="12" height="12" viewbox="0 0 50 50" preserveAspectRatio="xMidYMid meet"
stroke="currentColor" stroke-width="6" stroke-linecap="round" vector-effect="non-scaling-size">
<path d="M12 25H38M25 12V38"/>
</svg>
</div><div class="font-size-btn font-size-minus" tyt-di="8rdLQ">
<svg width="12" height="12" viewbox="0 0 50 50" preserveAspectRatio="xMidYMid meet"
stroke="currentColor" stroke-width="6" stroke-linecap="round" vector-effect="non-scaling-size">
<path d="M12 25h26"/>
</svg>
</div>
</div>
`.replace(/[\r\n]+/g, "");
const str_tabs = [
`<a id="tab-btn1" tyt-di="q9Kjc" tyt-tab-content="#tab-info" class="tab-btn${(hiddenTabsByUserCSS & 1) === 1 ? " tab-btn-hidden" : ""}">${sTabBtnInfo}${str1}${str_fbtns}</a>`,
`<a id="tab-btn3" tyt-di="q9Kjc" tyt-tab-content="#tab-comments" class="tab-btn${(hiddenTabsByUserCSS & 2) === 2 ? " tab-btn-hidden" : ""}">${svgElm(
16,
16,
120,
120,
svgComments
)}<span id="tyt-cm-count"></span>${str1}${str_fbtns}</a>`,
`<a id="tab-btn4" tyt-di="q9Kjc" tyt-tab-content="#tab-videos" class="tab-btn${(hiddenTabsByUserCSS & 4) === 4 ? " tab-btn-hidden" : ""}">${sTabBtnVideos}${str1}${str_fbtns}</a>`,
`<a id="tab-btn5" tyt-di="q9Kjc" tyt-tab-content="#tab-list" class="tab-btn tab-btn-hidden">${sTabBtnPlayList}${str1}${str_fbtns}</a>`
].join("");
let addHTML = `
<div id="right-tabs">
<tabview-view-pos-thead></tabview-view-pos-thead>
<header>
<div id="material-tabs">
${str_tabs}
</div>
</header>
<div class="tab-content">
<div id="tab-info" class="tab-content-cld tab-content-hidden" tyt-hidden userscript-scrollbar-render></div>
<div id="tab-comments" class="tab-content-cld tab-content-hidden" tyt-hidden userscript-scrollbar-render></div>
<div id="tab-videos" class="tab-content-cld tab-content-hidden" tyt-hidden userscript-scrollbar-render></div>
<div id="tab-list" class="tab-content-cld tab-content-hidden" tyt-hidden userscript-scrollbar-render></div>
</div>
</div>
`;
return addHTML;
}, getLang = function() {
let lang = "en";
let htmlLang = ((document || 0).documentElement || 0).lang || "";
switch (htmlLang) {
case "en":
case "en-GB":
lang = "en";
break;
case "de":
case "de-DE":
lang = "du";
break;
case "fr":
case "fr-CA":
case "fr-FR":
lang = "fr";
break;
case "zh-Hant":
case "zh-Hant-HK":
case "zh-Hant-TW":
lang = "tw";
break;
case "zh-Hans":
case "zh-Hans-CN":
lang = "cn";
break;
case "ja":
case "ja-JP":
lang = "jp";
break;
case "ko":
case "ko-KR":
lang = "kr";
break;
case "ru":
case "ru-RU":
lang = "ru";
break;
default:
lang = "en";
}
return lang;
}, getLangForPage = function() {
let lang = getLang();
if (langWords[lang])
pageLang = lang;
else
pageLang = "en";
}, isTheater = function() {
const ytdFlexyElm = elements.flexy;
return ytdFlexyElm && ytdFlexyElm.hasAttribute000("theater");
}, ytBtnSetTheater = function() {
if (!isTheater()) {
const sizeBtn = document.querySelector(
"ytd-watch-flexy #ytd-player button.ytp-size-button"
);
if (sizeBtn)
sizeBtn.click();
}
}, ytBtnCancelTheater = function() {
if (isTheater()) {
const sizeBtn = document.querySelector(
"ytd-watch-flexy #ytd-player button.ytp-size-button"
);
if (sizeBtn)
sizeBtn.click();
}
}, ytBtnExpandChat = function() {
let button = document.querySelector(
"ytd-live-chat-frame#chat[collapsed] > .ytd-live-chat-frame#show-hide-button"
);
if (button) {
button = button.querySelector000("div.yt-spec-touch-feedback-shape") || button.querySelector000("ytd-toggle-button-renderer");
if (button)
button.click();
}
}, ytBtnCollapseChat = function() {
let button = document.querySelector(
"ytd-live-chat-frame#chat:not([collapsed]) > .ytd-live-chat-frame#show-hide-button"
);
if (button) {
button = button.querySelector000("div.yt-spec-touch-feedback-shape") || button.querySelector000("ytd-toggle-button-renderer");
if (button)
button.click();
}
}, ytBtnEgmPanelCore = function(arr) {
if (!arr)
return;
if (!("length" in arr))
arr = [arr];
const ytdFlexyElm = elements.flexy;
if (!ytdFlexyElm)
return;
let actions = [];
for (const entry of arr) {
if (!entry)
continue;
let panelId = entry.panelId;
let toHide = entry.toHide;
let toShow = entry.toShow;
if (toHide === true && !toShow) {
actions.push({
changeEngagementPanelVisibilityAction: {
targetId: panelId,
visibility: "ENGAGEMENT_PANEL_VISIBILITY_HIDDEN"
}
});
} else if (toShow === true && !toHide) {
actions.push({
showEngagementPanelEndpoint: {
panelIdentifier: panelId
}
});
}
if (actions.length > 0) {
const cnt = insp(ytdFlexyElm);
cnt.resolveCommand(
{
signalServiceEndpoint: {
signal: "CLIENT_SIGNAL",
actions
}
},
{},
false
);
}
actions = null;
}
}, ytBtnCloseEngagementPanels = function() {
const actions = [];
for (const panelElm of document.querySelectorAll(
`ytd-watch-flexy[flexy][tyt-tab] #panels.ytd-watch-flexy ytd-engagement-panel-section-list-renderer[target-id][visibility]:not([hidden])`
)) {
if (panelElm.getAttribute("visibility") == "ENGAGEMENT_PANEL_VISIBILITY_EXPANDED" && !panelElm.closest("[hidden]")) {
actions.push({
panelId: panelElm.getAttribute000("target-id"),
toHide: true
});
}
}
ytBtnEgmPanelCore(actions);
}, ytBtnOpenPlaylist = function() {
const cnt = insp(elements.playlist);
if (cnt && typeof cnt.collapsed === "boolean") {
cnt.collapsed = false;
}
}, ytBtnClosePlaylist = function() {
const cnt = insp(elements.playlist);
if (cnt && typeof cnt.collapsed === "boolean") {
cnt.collapsed = true;
}
};
let executionFinished = 0;
if (typeof CustomElementRegistry === "undefined")
return;
if (CustomElementRegistry.prototype.define000)
return;
if (typeof CustomElementRegistry.prototype.define !== "function")
return;
const HTMLElement_ = HTMLElement.prototype.constructor;
const qsOne = (elm, selector) => {
return HTMLElement_.prototype.querySelector.call(elm, selector);
};
const qsAll = (elm, selector) => {
return HTMLElement_.prototype.querySelectorAll.call(elm, selector);
};
const pdsBaseDF = Object.getOwnPropertyDescriptors(
DocumentFragment.prototype
);
Object.defineProperties(DocumentFragment.prototype, {
replaceChildren000: pdsBaseDF.replaceChildren
});
const pdsBaseNode = Object.getOwnPropertyDescriptors(Node.prototype);
Object.defineProperties(Node.prototype, {
appendChild000: pdsBaseNode.appendChild,
insertBefore000: pdsBaseNode.insertBefore
});
const pdsBaseElement = Object.getOwnPropertyDescriptors(Element.prototype);
Object.defineProperties(Element.prototype, {
setAttribute000: pdsBaseElement.setAttribute,
getAttribute000: pdsBaseElement.getAttribute,
hasAttribute000: pdsBaseElement.hasAttribute,
removeAttribute000: pdsBaseElement.removeAttribute,
querySelector000: pdsBaseElement.querySelector,
replaceChildren000: pdsBaseElement.replaceChildren
});
Element.prototype.setAttribute111 = function(p, v) {
v = `${v}`;
if (this.getAttribute000(p) === v)
return;
this.setAttribute000(p, v);
};
Element.prototype.incAttribute111 = function(p) {
let v = +this.getAttribute000(p) || 0;
v = v > 1e9 ? v + 1 : 9;
this.setAttribute000(p, `${v}`);
return v;
};
Element.prototype.assignChildern111 = function(previousSiblings, node, nextSiblings) {
let nodeList = [];
for (let t = this.firstChild; t instanceof Node; t = t.nextSibling) {
if (t === node)
continue;
nodeList.push(t);
}
inPageRearrange = true;
if (node.parentNode === this) {
let fm = new DocumentFragment();
if (nodeList.length > 0) {
fm.replaceChildren000(...nodeList);
}
if (previousSiblings && previousSiblings.length > 0) {
fm.replaceChildren000(...previousSiblings);
this.insertBefore000(fm, node);
}
if (nextSiblings && nextSiblings.length > 0) {
fm.replaceChildren000(...nextSiblings);
this.appendChild000(fm);
}
fm.replaceChildren000();
fm = null;
} else {
if (!previousSiblings)
previousSiblings = [];
if (!nextSiblings)
nextSiblings = [];
this.replaceChildren000(...previousSiblings, node, ...nextSiblings);
}
inPageRearrange = false;
if (nodeList.length > 0) {
for (const t of nodeList) {
if (t instanceof Element && t.isConnected === false)
t.remove();
}
}
nodeList.length = 0;
nodeList = null;
};
const DISABLE_FLAGS_SHADYDOM_FREE = true;
(() => {
let e = "undefined" != typeof unsafeWindow ? unsafeWindow : void 0 instanceof Window ? void 0 : window;
if (!e._ytConfigHacks) {
let r = function(t2) {
o(), t2 && e.removeEventListener("DOMContentLoaded", r, false);
};
let t = 4;
class n extends Set {
add(e2) {
if (t <= 0)
return void 0;
"function" == typeof e2 && super.add(e2);
}
}
let a = (async () => {
})().constructor, i = e._ytConfigHacks = new n(), l = () => {
let t2 = e.ytcsi.originalYtcsi;
t2 && (e.ytcsi = t2, l = null);
}, c = null, o = () => {
if (t >= 1) {
let n2 = (e.yt || 0).config_ || (e.ytcfg || 0).data_ || 0;
if ("string" == typeof n2.INNERTUBE_API_KEY && "object" == typeof n2.EXPERIMENT_FLAGS)
for (let a2 of (--t <= 0 && l && l(), c = true, i))
a2(n2);
}
}, f = 1, d = (t2) => {
if (t2 = t2 || e.ytcsi)
return e.ytcsi = new Proxy(t2, {
get: (e2, t3, n2) => "originalYtcsi" === t3 ? e2 : (o(), c && --f <= 0 && l && l(), e2[t3])
}), true;
};
d() || Object.defineProperty(e, "ytcsi", {
get() {
},
set: (t2) => (t2 && (delete e.ytcsi, d(t2)), true),
enumerable: false,
configurable: true
});
let { addEventListener: s, removeEventListener: y } = Document.prototype;
new a((e2) => {
if ("undefined" != typeof AbortSignal)
s.call(document, "yt-page-data-fetched", e2, { once: true }), s.call(document, "yt-navigate-finish", e2, { once: true }), s.call(document, "spfdone", e2, { once: true });
else {
let t2 = () => {
e2(), y.call(document, "yt-page-data-fetched", t2, false), y.call(document, "yt-navigate-finish", t2, false), y.call(document, "spfdone", t2, false);
};
s.call(document, "yt-page-data-fetched", t2, false), s.call(document, "yt-navigate-finish", t2, false), s.call(document, "spfdone", t2, false);
}
}).then(o), new a((e2) => {
if ("undefined" != typeof AbortSignal)
s.call(document, "yt-action", e2, { once: true, capture: true });
else {
let t2 = () => {
e2(), y.call(document, "yt-action", t2, true);
};
s.call(document, "yt-action", t2, true);
}
}).then(o), a.resolve().then(() => {
"loading" !== document.readyState ? r() : e.addEventListener("DOMContentLoaded", r, false);
});
}
})();
let configOnce = false;
window._ytConfigHacks.add((config_) => {
if (configOnce)
return;
configOnce = true;
const EXPERIMENT_FLAGS = config_.EXPERIMENT_FLAGS || 0;
const EXPERIMENTS_FORCED_FLAGS = config_.EXPERIMENTS_FORCED_FLAGS || 0;
for (const flags of [EXPERIMENT_FLAGS, EXPERIMENTS_FORCED_FLAGS]) {
if (flags) {
flags.web_watch_chat_hide_button_killswitch = false;
flags.web_watch_theater_chat = false;
flags.suppress_error_204_logging = true;
flags.kevlar_watch_grid = false;
if (DISABLE_FLAGS_SHADYDOM_FREE) {
flags.enable_shadydom_free_scoped_node_methods = false;
flags.enable_shadydom_free_scoped_query_methods = false;
flags.enable_shadydom_free_scoped_readonly_properties_batch_one = false;
flags.enable_shadydom_free_parent_node = false;
flags.enable_shadydom_free_children = false;
flags.enable_shadydom_free_last_child = false;
}
}
}
});
const mWeakRef = typeof WeakRef === "function" ? (o) => o ? new WeakRef(o) : null : (o) => o || null;
const kRef = (wr) => wr && wr.deref ? wr.deref() : wr;
const Promise = (async () => {
})().constructor;
const delayPn = (delay) => new Promise((fn) => setTimeout(fn, delay));
const insp = (o) => o ? o.polymerController || o.inst || o || 0 : o || 0;
const PromiseExternal = ((resolve_, reject_) => {
const h = (resolve, reject) => {
resolve_ = resolve;
reject_ = reject;
};
return class PromiseExternal extends Promise {
constructor(cb = h) {
super(cb);
if (cb === h) {
this.resolve = resolve_;
this.reject = reject_;
}
}
};
})();
!function(e) {
"use strict";
if (e.nextBrowserTick)
return;
if (!function() {
if (e.postMessage && !e.importScripts && e.addEventListener) {
let t2 = true, s2 = () => {
t2 = false;
};
return e.addEventListener("message", s2, false), e.postMessage("", "*"), e.removeEventListener("message", s2, false), t2;
}
}())
return void 0;
const t = (async () => {
})().constructor, s = ((e2, s2) => {
const n2 = (t2, n3) => {
e2 = t2, s2 = n3;
};
return class extends t {
constructor(t2 = n2) {
super(t2), t2 === n2 && (this.resolve = e2, this.reject = s2);
}
};
})();
let n, r = null;
do {
n = `$$nextBrowserTick$$${(Math.random() + 8).toString().slice(2)}$$`;
} while (n in e);
const o = n;
e[o] = 1;
e.addEventListener(
"message",
(e2) => {
(null !== r ? (e2 || 0).data : 0) === o && e2.source === (e2.target || 1) && r.resolve(r = null);
},
false
), e.nextBrowserTick = (t2) => {
r || (r = new s(), e.postMessage(o, "*")), r.then(t2).catch(console.warn);
};
}(
"undefined" == typeof self ? "undefined" == typeof global ? void 0 : global : self
);
const isPassiveArgSupport = typeof IntersectionObserver === "function";
const bubblePassive = isPassiveArgSupport ? { capture: false, passive: true } : false;
const capturePassive = isPassiveArgSupport ? { capture: true, passive: true } : true;
class Attributer {
constructor(list) {
this.list = list;
this.flag = 0;
}
makeString() {
let k = 1;
let s = "";
let i = 0;
while (this.flag >= k) {
if (this.flag & k) {
s += this.list[i];
}
i++;
k <<= 1;
}
return s;
}
}
const mLoaded = new Attributer("icp");
const wrSelfMap = /* @__PURE__ */ new WeakMap();
const elements = new Proxy(
{
related: null,
comments: null,
infoExpander: null
},
{
get(target, prop) {
return kRef(target[prop]);
},
set(target, prop, value) {
if (value) {
let wr = wrSelfMap.get(value);
if (!wr) {
wr = mWeakRef(value);
wrSelfMap.set(value, wr);
}
target[prop] = wr;
} else {
target[prop] = null;
}
return true;
}
}
);
const getMainInfo = () => {
const infoExpander = elements.infoExpander;
if (!infoExpander)
return null;
const mainInfo = infoExpander.matches("[tyt-main-info]") ? infoExpander : infoExpander.querySelector000("[tyt-main-info]");
return mainInfo || null;
};
const asyncWrap = (asyncFn) => {
return () => {
Promise.resolve().then(asyncFn);
};
};
let pageType = null;
let pageLang = "en";
const langWords = {
en: {
info: "Info",
videos: "Videos",
playlist: "Playlist"
},
jp: {
info: "情報",
videos: "動画",
playlist: "再生リスト"
},
tw: {
info: "資訊",
videos: "影片",
playlist: "播放清單"
},
cn: {
info: "资讯",
videos: "视频",
playlist: "播放列表"
},
du: {
info: "Info",
videos: "Videos",
playlist: "Playlist"
},
fr: {
info: "Info",
videos: "Vidéos",
playlist: "Playlist"
},
kr: {
info: "정보",
videos: "동영상",
playlist: "재생목록"
},
ru: {
info: "Описание",
videos: "Видео",
playlist: "Плейлист"
}
};
const svgComments = `<path d="M80 27H12A12 12 90 0 0 0 39v42a12 12 90 0 0 12 12h12v20a2 2 90 0 0 3.4 2L47 93h33a12
12 90 0 0 12-12V39a12 12 90 0 0-12-12zM20 47h26a2 2 90 1 1 0 4H20a2 2 90 1 1 0-4zm52 28H20a2 2 90 1 1 0-4h52a2 2 90
1 1 0 4zm0-12H20a2 2 90 1 1 0-4h52a2 2 90 1 1 0 4zm36-58H40a12 12 90 0 0-12 12v6h52c9 0 16 7 16 16v42h0v4l7 7a2 2 90
0 0 3-1V71h2a12 12 90 0 0 12-12V17a12 12 90 0 0-12-12z"/>`.trim();
const svgVideos = `<path d="M89 10c0-4-3-7-7-7H7c-4 0-7 3-7 7v70c0 4 3 7 7 7h75c4 0 7-3 7-7V10zm-62 2h13v10H27V12zm-9
66H9V68h9v10zm0-56H9V12h9v10zm22 56H27V68h13v10zm-3-25V36c0-2 2-3 4-2l12 8c2 1 2 4 0 5l-12 8c-2 1-4 0-4-2zm25
25H49V68h13v10zm0-56H49V12h13v10zm18 56h-9V68h9v10zm0-56h-9V12h9v10z"/>`.trim();
const svgInfo = `<path d="M30 0C13.3 0 0 13.3 0 30s13.3 30 30 30 30-13.3 30-30S46.7 0 30 0zm6.2 46.6c-1.5.5-2.6
1-3.6 1.3a10.9 10.9 0 0 1-3.3.5c-1.7 0-3.3-.5-4.3-1.4a4.68 4.68 0 0 1-1.6-3.6c0-.4.2-1 .2-1.5a20.9 20.9 90 0 1
.3-2l2-6.8c.1-.7.3-1.3.4-1.9a8.2 8.2 90 0 0 .3-1.6c0-.8-.3-1.4-.7-1.8s-1-.5-2-.5a4.53 4.53 0 0 0-1.6.3c-.5.2-1
.2-1.3.4l.6-2.1c1.2-.5 2.4-1 3.5-1.3s2.3-.6 3.3-.6c1.9 0 3.3.6 4.3 1.3s1.5 2.1 1.5 3.5c0 .3 0 .9-.1 1.6a10.4 10.4
90 0 1-.4 2.2l-1.9 6.7c-.2.5-.2 1.1-.4 1.8s-.2 1.3-.2 1.6c0 .9.2 1.6.6 1.9s1.1.5 2.1.5a6.1 6.1 90 0 0 1.5-.3 9 9 90
0 0 1.4-.4l-.6 2.2zm-3.8-35.2a1 1 0 010 8.6 1 1 0 010-8.6z"/>`.trim();
const svgPlayList = `<path d="M0 3h12v2H0zm0 4h12v2H0zm0 4h8v2H0zm16 0V7h-2v4h-4v2h4v4h2v-4h4v-2z"/>`.trim();
const svgDiag1 = `<svg stroke="currentColor" fill="none"><path d="M8 2h2v2M7 5l3-3m-6 8H2V8m0 2l3-3"/></svg>`;
const svgDiag2 = `<svg stroke="currentColor" fill="none"><path d="M7 3v2h2M7 5l3-3M5 9V7H3m-1 3l3-3"/></svg>`;
const getGMT = () => {
let m = new Date("2023-01-01T00:00:00Z");
return m.getDate() === 1 ? `+${m.getHours()}` : `-${24 - m.getHours()}`;
};
const svgElm = (w, h, vw, vh, p, m) => `<svg${m ? ` class=${m}` : ""} width="${w}" height="${h}" viewBox="0 0 ${vw} ${vh}" preserveAspectRatio="xMidYMid meet">${p}</svg>`;
let hiddenTabsByUserCSS = 0;
const _locks = {};
const lockGet = new Proxy(_locks, {
get(target, prop) {
return target[prop] || 0;
},
set(target, prop, val) {
return true;
}
});
const lockSet = new Proxy(_locks, {
get(target, prop) {
if (target[prop] > 1e9)
target[prop] = 9;
return target[prop] = (target[prop] || 0) + 1;
},
set(target, prop, val) {
return true;
}
});
const videosElementProvidedPromise = new PromiseExternal();
const navigateFinishedPromise = new PromiseExternal();
let isRightTabsInserted = false;
const rightTabsProvidedPromise = new PromiseExternal();
const infoExpanderElementProvidedPromise = new PromiseExternal();
const funcCanCollapse = function(s) {
if (!s)
return;
this.canToggle = this.shouldUseNumberOfLines && (this.alwaysCollapsed || this.collapsed) ? this.alwaysToggleable || this.$.content.offsetHeight < this.$.content.scrollHeight : this.alwaysToggleable || this.$.content.scrollHeight > this.collapsedHeight;
};
const aoChatAttrChangeFn = async (lockId) => {
if (lockGet["aoChatAttrAsyncLock"] !== lockId)
return;
const chatElm = elements.chat;
const ytdFlexyElm = elements.flexy;
if (chatElm && ytdFlexyElm) {
const isChatCollapsed = chatElm.hasAttribute000("collapsed");
if (isChatCollapsed) {
ytdFlexyElm.setAttribute111("tyt-chat-collapsed", "");
} else {
ytdFlexyElm.removeAttribute000("tyt-chat-collapsed");
}
ytdFlexyElm.setAttribute111("tyt-chat", isChatCollapsed ? "-" : "+");
}
};
const aoPlayListAttrChangeFn = async (lockId) => {
if (lockGet["aoPlayListAttrAsyncLock"] !== lockId)
return;
const playlistElm = elements.playlist;
const ytdFlexyElm = elements.flexy;
if (playlistElm && ytdFlexyElm) {
if (playlistElm.hasAttribute000("collapsed")) {
ytdFlexyElm.removeAttribute000("tyt-playlist-expanded");
} else {
ytdFlexyElm.setAttribute111("tyt-playlist-expanded", "");
}
} else if (ytdFlexyElm) {
ytdFlexyElm.removeAttribute000("tyt-playlist-expanded");
}
};
const aoChat = new MutationObserver(() => {
Promise.resolve(lockSet["aoChatAttrAsyncLock"]).then(aoChatAttrChangeFn).catch(console.warn);
});
const aoPlayList = new MutationObserver(() => {
Promise.resolve(lockSet["aoPlayListAttrAsyncLock"]).then(aoPlayListAttrChangeFn).catch(console.warn);
});
const aoComment = new MutationObserver(async (mutations) => {
const commentsArea = elements.comments;
const ytdFlexyElm = elements.flexy;
if (!commentsArea)
return;
let bfHidden = false;
let bfCommentsVideoId = false;
let bfCommentDisabled = false;
for (const mutation of mutations) {
if (mutation.attributeName === "hidden" && mutation.target === commentsArea) {
bfHidden = true;
} else if (mutation.attributeName === "tyt-comments-video-id" && mutation.target === commentsArea) {
bfCommentsVideoId = true;
} else if (mutation.attributeName === "tyt-comments-data-status" && mutation.target === commentsArea) {
bfCommentDisabled = true;
}
}
if (bfHidden) {
if (!commentsArea.hasAttribute000("hidden")) {
Promise.resolve(commentsArea).then(eventMap["settingCommentsVideoId"]).catch(console.warn);
}
Promise.resolve(lockSet["removeKeepCommentsScrollerLock"]).then(removeKeepCommentsScroller).catch(console.warn);
}
if ((bfHidden || bfCommentsVideoId || bfCommentDisabled) && ytdFlexyElm) {
const commentsDataStatus = +commentsArea.getAttribute000(
"tyt-comments-data-status"
);
if (commentsDataStatus === 2) {
ytdFlexyElm.setAttribute111("tyt-comment-disabled", "");
} else if (commentsDataStatus === 1) {
ytdFlexyElm.removeAttribute000("tyt-comment-disabled");
}
Promise.resolve(lockSet["checkCommentsShouldBeHiddenLock"]).then(eventMap["checkCommentsShouldBeHidden"]).catch(console.warn);
const lockId = lockSet["rightTabReadyLock01"];
await rightTabsProvidedPromise.then();
if (lockGet["rightTabReadyLock01"] !== lockId)
return;
if (elements.comments !== commentsArea)
return;
if (commentsArea.isConnected === false)
return;
if (commentsArea.closest("#tab-comments")) {
const shouldTabVisible = !commentsArea.closest("[hidden]");
document.querySelector('[tyt-tab-content="#tab-comments"]').classList.toggle("tab-btn-hidden", !shouldTabVisible);
}
}
});
const ioComment = new IntersectionObserver(
(entries) => {
for (const entry of entries) {
const target = entry.target;
const cnt = insp(target);
if (entry.isIntersecting && target instanceof HTMLElement_ && typeof cnt.calculateCanCollapse === "function") {
lockSet["removeKeepCommentsScrollerLock"];
cnt.calculateCanCollapse(true);
target.setAttribute111("io-intersected", "");
const ytdFlexyElm = elements.flexy;
if (ytdFlexyElm && !ytdFlexyElm.hasAttribute000("keep-comments-scroller")) {
ytdFlexyElm.setAttribute111("keep-comments-scroller", "");
}
} else if (target.hasAttribute000("io-intersected")) {
target.removeAttribute000("io-intersected");
}
}
},
{
threshold: [0],
rootMargin: "32px"
}
);
let bFixForResizedTabLater = false;
let lastRoRightTabsWidth = 0;
const roRightTabs = new ResizeObserver((entries) => {
const entry = entries[entries.length - 1];
const width = Math.round(entry.borderBoxSize.inlineSize);
if (lastRoRightTabsWidth !== width) {
lastRoRightTabsWidth = width;
if ((tabAStatus & 2) === 2) {
bFixForResizedTabLater = false;
Promise.resolve(1).then(eventMap["fixForTabDisplay"]);
} else {
bFixForResizedTabLater = true;
}
}
});
const switchToTab = (activeLink) => {
if (typeof activeLink === "string") {
activeLink = document.querySelector(`a[tyt-tab-content="${activeLink}"]`) || null;
}
const ytdFlexyElm = elements.flexy;
const links = document.querySelectorAll(
"#material-tabs a[tyt-tab-content]"
);
for (const link of links) {
const content = document.querySelector(
link.getAttribute000("tyt-tab-content")
);
if (link && content) {
if (link !== activeLink) {
link.classList.remove("active");
content.classList.add("tab-content-hidden");
if (!content.hasAttribute000("tyt-hidden")) {
content.setAttribute111("tyt-hidden", "");
}
} else {
link.classList.add("active");
if (content.hasAttribute000("tyt-hidden")) {
content.removeAttribute000("tyt-hidden");
}
content.classList.remove("tab-content-hidden");
}
}
}
const switchingTo = activeLink ? activeLink.getAttribute000("tyt-tab-content") : "";
if (switchingTo) {
lastTab = lastPanel = switchingTo;
}
if (ytdFlexyElm.getAttribute000("tyt-chat") === "")
ytdFlexyElm.removeAttribute000("tyt-chat");
ytdFlexyElm.setAttribute111("tyt-tab", switchingTo);
if (switchingTo) {
bFixForResizedTabLater = false;
Promise.resolve(0).then(eventMap["fixForTabDisplay"]);
}
};
let tabAStatus = 0;
const calculationFn = (r = 0, flag) => {
const ytdFlexyElm = elements.flexy;
if (!ytdFlexyElm)
return r;
if (flag & 1) {
r |= 1;
if (!ytdFlexyElm.hasAttribute000("theater"))
r -= 1;
}
if (flag & 2) {
r |= 2;
if (!ytdFlexyElm.getAttribute000("tyt-tab"))
r -= 2;
}
if (flag & 4) {
r |= 4;
if (ytdFlexyElm.getAttribute000("tyt-chat") !== "-")
r -= 4;
}
if (flag & 8) {
r |= 8;
if (ytdFlexyElm.getAttribute000("tyt-chat") !== "+")
r -= 8;
}
if (flag & 16) {
r |= 16;
if (!ytdFlexyElm.hasAttribute000("is-two-columns_"))
r -= 16;
}
if (flag & 32) {
r |= 32;
if (!ytdFlexyElm.hasAttribute000("tyt-egm-panel_"))
r -= 32;
}
if (flag & 64) {
r |= 64;
if (!document.fullscreenElement)
r -= 64;
}
if (flag & 128) {
r |= 128;
if (!ytdFlexyElm.hasAttribute000("tyt-playlist-expanded"))
r -= 128;
}
return r;
};
const updateChatLocation498 = function() {
if (this.is !== "ytd-watch-grid") {
this.updatePageMediaQueries();
this.schedulePlayerSizeUpdate_();
}
};
const mirrorNodeWS = /* @__PURE__ */ new WeakMap();
const dummyNode = document.createElement("noscript");
const __j4836__ = Symbol();
const __j5744__ = Symbol();
const __j5733__ = Symbol();
const monitorDataChangedByDOMMutation = async function(mutations) {
const nodeWR = this;
const node = kRef(nodeWR);
if (!node)
return;
const cnt = insp(node);
const __lastChanged__ = cnt[__j5733__];
const val = cnt.data ? cnt.data[__j4836__] || 1 : 0;
if (__lastChanged__ !== val) {
cnt[__j5733__] = val > 0 ? cnt.data[__j4836__] = Date.now() : 0;
await Promise.resolve();
attributeInc(node, "tyt-data-change-counter");
}
};
const moChangeReflection = function(mutations) {
const nodeWR = this;
const node = kRef(nodeWR);
if (!node)
return;
const originElement = kRef(node[__j5744__] || null) || null;
if (!originElement)
return;
const cnt = insp(node);
const oriCnt = insp(originElement);
if (mutations) {
let bfDataChangeCounter = false;
for (const mutation of mutations) {
if (mutation.attributeName === "tyt-clone-refresh-count" && mutation.target === originElement) {
bfDataChangeCounter = true;
} else if (mutation.attributeName === "tyt-data-change-counter" && mutation.target === originElement) {
bfDataChangeCounter = true;
}
}
if (bfDataChangeCounter && oriCnt.data) {
node.replaceWith(dummyNode);
cnt.data = Object.assign({}, oriCnt.data);
dummyNode.replaceWith(node);
}
}
};
const attributeInc = (elm, prop) => {
let v = (+elm.getAttribute000(prop) || 0) + 1;
if (v > 1e9)
v = 9;
elm.setAttribute000(prop, v);
return v;
};
const isChannelId = (x) => {
if (typeof x === "string" && x.length === 24) {
return /UC[-_a-zA-Z0-9+=.]{22}/.test(x);
}
return false;
};
const infoFix = (lockId) => {
if (lockId !== null && lockGet["infoFixLock"] !== lockId)
return;
const infoExpander = elements.infoExpander;
const infoContainer = (infoExpander ? infoExpander.parentNode : null) || document.querySelector("#tab-info");
const ytdFlexyElm = elements.flexy;
if (!infoContainer || !ytdFlexyElm)
return;
if (infoExpander) {
const match = infoExpander.matches("#tab-info > [class]") || infoExpander.matches("#tab-info > [tyt-main-info]");
if (!match)
return;
}
const requireElements = [
...document.querySelectorAll(
'ytd-watch-metadata.ytd-watch-flexy div[slot="extra-content"] > *, ytd-watch-metadata.ytd-watch-flexy #extra-content > *'
)
].filter((elm) => {
return typeof elm.is == "string";
}).map((elm) => {
const is = elm.is;
while (elm instanceof HTMLElement_) {
const q = [...elm.querySelectorAll(is)].filter((e) => insp(e).data);
if (q.length >= 1)
return q[0];
elm = elm.parentNode;
}
}).filter((elm) => !!elm && typeof elm.is === "string");
const source = requireElements.map((entry) => {
const inst = insp(entry);
return {
data: inst.data,
tag: inst.is,
elm: entry
};
});
let noscript_ = document.querySelector("noscript#aythl");
if (!noscript_) {
noscript_ = document.createElement("noscript");
noscript_.id = "aythl";
inPageRearrange = true;
ytdFlexyElm.insertBefore000(noscript_, ytdFlexyElm.firstChild);
inPageRearrange = false;
}
const noscript = noscript_;
let requiredUpdate = false;
const mirrorElmSet = /* @__PURE__ */ new Set();
const targetParent = infoContainer;
for (const { data, tag, elm: s } of source) {
let mirrorNode = mirrorNodeWS.get(s);
mirrorNode = mirrorNode ? kRef(mirrorNode) : mirrorNode;
if (!mirrorNode) {
const cnt = insp(s);
const cProto = cnt.constructor.prototype;
const element = document.createElement(tag);
noscript.appendChild(element);
mirrorNode = element;
mirrorNode[__j5744__] = mWeakRef(s);
const nodeWR = mWeakRef(mirrorNode);
new MutationObserver(moChangeReflection.bind(nodeWR)).observe(s, {
attributes: true,
attributeFilter: [
"tyt-clone-refresh-count",
"tyt-data-change-counter"
]
});
s.jy8432 = 1;
if (!(cProto instanceof Node) && !cProto._dataChanged496 && typeof cProto._createPropertyObserver === "function") {
cProto._dataChanged496 = function() {
const cnt2 = this;
const node = cnt2.hostElement || cnt2;
if (node.jy8432) {
attributeInc(node, "tyt-data-change-counter");
}
};
cProto._createPropertyObserver(
"data",
"_dataChanged496",
void 0
);
} else if (!(cProto instanceof Node) && !cProto._dataChanged496 && cProto.useSignals === true && insp(s).signalProxy) {
const dataSignal = cnt?.signalProxy?.signalCache?.data;
if (dataSignal && typeof dataSignal.setWithPath === "function" && !dataSignal.setWithPath573 && !dataSignal.controller573) {
dataSignal.controller573 = mWeakRef(cnt);
dataSignal.setWithPath573 = dataSignal.setWithPath;
dataSignal.setWithPath = function() {
const cnt2 = kRef(this.controller573 || null) || null;
cnt2 && typeof cnt2._dataChanged496k === "function" && Promise.resolve(cnt2).then(cnt2._dataChanged496k).catch(console.warn);
return this.setWithPath573(...arguments);
};
cProto._dataChanged496 = function() {
const cnt2 = this;
const node = cnt2.hostElement || cnt2;
if (node.jy8432) {
attributeInc(node, "tyt-data-change-counter");
}
};
cProto._dataChanged496k = (cnt2) => cnt2._dataChanged496();
}
}
if (!cProto._dataChanged496) {
new MutationObserver(
monitorDataChangedByDOMMutation.bind(mirrorNode[__j5744__])
).observe(s, { attributes: true, childList: true, subtree: true });
}
mirrorNodeWS.set(s, nodeWR);
requiredUpdate = true;
} else {
if (mirrorNode.parentNode !== targetParent) {
requiredUpdate = true;
}
}
if (!requiredUpdate) {
const cloneNodeCnt = insp(mirrorNode);
if (cloneNodeCnt.data !== data) {
requiredUpdate = true;
}
}
mirrorElmSet.add(mirrorNode);
source.mirrored = mirrorNode;
}
const mirroElmArr = [...mirrorElmSet];
mirrorElmSet.clear();
if (!requiredUpdate) {
let e = infoExpander ? -1 : 0;
for (let n = targetParent.firstChild; n instanceof Node; n = n.nextSibling) {
let target = e < 0 ? infoExpander : mirroElmArr[e];
e++;
if (n !== target) {
requiredUpdate = true;
break;
}
}
if (!requiredUpdate && e !== mirroElmArr.length + 1)
requiredUpdate = true;
}
if (requiredUpdate) {
if (infoExpander) {
targetParent.assignChildern111(null, infoExpander, mirroElmArr);
} else {
targetParent.replaceChildren000(...mirroElmArr);
}
for (const mirrorElm of mirroElmArr) {
const j = attributeInc(mirrorElm, "tyt-clone-refresh-count");
const oriElm = kRef(mirrorElm[__j5744__] || null) || null;
if (oriElm) {
oriElm.setAttribute111("tyt-clone-refresh-count", j);
}
}
}
mirroElmArr.length = 0;
source.length = 0;
};
const layoutFix = (lockId) => {
if (lockGet["layoutFixLock"] !== lockId)
return;
const secondaryWrapper = document.querySelector(
"#secondary-inner.style-scope.ytd-watch-flexy > secondary-wrapper"
);
if (secondaryWrapper) {
const secondaryInner = secondaryWrapper.parentNode;
const chatContainer = document.querySelector(
"#columns.style-scope.ytd-watch-flexy [tyt-chat-container]"
);
if (secondaryInner.firstChild !== secondaryInner.lastChild || chatContainer && !chatContainer.closest("secondary-wrapper")) {
let w = [];
let w2 = [];
for (let node = secondaryInner.firstChild; node instanceof Node; node = node.nextSibling) {
if (node === chatContainer && chatContainer) {
} else if (node === secondaryWrapper) {
for (let node2 = secondaryWrapper.firstChild; node2 instanceof Node; node2 = node2.nextSibling) {
if (node2 === chatContainer && chatContainer) {
} else {
if (node2.id === "right-tabs" && chatContainer) {
w2.push(chatContainer);
}
w2.push(node2);
}
}
} else {
w.push(node);
}
}
inPageRearrange = true;
secondaryWrapper.replaceChildren000(...w, ...w2);
inPageRearrange = false;
const chatElm = elements.chat;
const chatCnt = insp(chatElm);
if (chatCnt && typeof chatCnt.urlChanged === "function" && secondaryWrapper.contains(chatElm)) {
if (typeof chatCnt.urlChangedAsync12 === "function") {
chatCnt.urlChanged();
} else {
setTimeout(() => chatCnt.urlChanged(), 136);
}
}
}
}
};
let lastPanel = "";
let lastTab = "";
const aoEgmPanels = new MutationObserver(() => {
Promise.resolve(lockSet["updateEgmPanelsLock"]).then(updateEgmPanels).catch(console.warn);
});
const removeKeepCommentsScroller = async (lockId) => {
if (lockGet["removeKeepCommentsScrollerLock"] !== lockId)
return;
await Promise.resolve();
if (lockGet["removeKeepCommentsScrollerLock"] !== lockId)
return;
const ytdFlexyFlm = elements.flexy;
if (ytdFlexyFlm) {
ytdFlexyFlm.removeAttribute000("keep-comments-scroller");
}
};
const updateEgmPanels = async (lockId) => {
if (lockId !== lockGet["updateEgmPanelsLock"])
return;
await navigateFinishedPromise.then().catch(console.warn);
if (lockId !== lockGet["updateEgmPanelsLock"])
return;
const ytdFlexyElm = elements.flexy;
if (!ytdFlexyElm)
return;
let newVisiblePanels = [];
let newHiddenPanels = [];
let allVisiblePanels = [];
for (const panelElm of document.querySelectorAll(
"[tyt-egm-panel][target-id][visibility]"
)) {
const visibility = panelElm.getAttribute000("visibility");
if (visibility === "ENGAGEMENT_PANEL_VISIBILITY_HIDDEN" || panelElm.closest("[hidden]")) {
if (panelElm.hasAttribute000("tyt-visible-at")) {
panelElm.removeAttribute000("tyt-visible-at");
newHiddenPanels.push(panelElm);
}
} else if (visibility === "ENGAGEMENT_PANEL_VISIBILITY_EXPANDED" && !panelElm.closest("[hidden]")) {
let visibleAt = panelElm.getAttribute000("tyt-visible-at");
if (!visibleAt) {
panelElm.setAttribute111("tyt-visible-at", Date.now());
newVisiblePanels.push(panelElm);
}
allVisiblePanels.push(panelElm);
}
}
if (newVisiblePanels.length >= 1 && allVisiblePanels.length >= 2) {
const targetVisible = newVisiblePanels[newVisiblePanels.length - 1];
const actions = [];
for (const panelElm of allVisiblePanels) {
if (panelElm === targetVisible)
continue;
actions.push({
panelId: panelElm.getAttribute000("target-id"),
toHide: true
});
}
if (actions.length >= 1) {
ytBtnEgmPanelCore(actions);
}
}
if (allVisiblePanels.length >= 1) {
ytdFlexyElm.setAttribute111("tyt-egm-panel_", "");
} else {
ytdFlexyElm.removeAttribute000("tyt-egm-panel_");
}
newVisiblePanels.length = 0;
newVisiblePanels = null;
newHiddenPanels.length = 0;
newHiddenPanels = null;
allVisiblePanels.length = 0;
allVisiblePanels = null;
};
const checkElementExist = (css, exclude) => {
for (const p of document.querySelectorAll(css)) {
if (!p.closest(exclude))
return p;
}
return null;
};
let fixInitialTabStateK = 0;
const { handleNavigateFactory } = (() => {
let isLoadStartListened = false;
function findLcComment(lc) {
if (arguments.length === 1) {
let element = document.querySelector(
`#tab-comments ytd-comments ytd-comment-renderer #header-author a[href*="lc=${lc}"]`
);
if (element) {
let commentRendererElm = closestFromAnchor.call(
element,
"ytd-comment-renderer"
);
if (commentRendererElm && lc) {
return {
lc,
commentRendererElm
};
}
}
} else if (arguments.length === 0) {
let element = document.querySelector(
`#tab-comments ytd-comments ytd-comment-renderer > #linked-comment-badge span:not(:empty)`
);
if (element) {
let commentRendererElm = closestFromAnchor.call(
element,
"ytd-comment-renderer"
);
if (commentRendererElm) {
let header = _querySelector.call(
commentRendererElm,
"#header-author"
);
if (header) {
let anchor = _querySelector.call(header, 'a[href*="lc="]');
if (anchor) {
let href = anchor.getAttribute("href") || "";
let m = /[&?]lc=([\w_.-]+)/.exec(href);
if (m) {
lc = m[1];
}
}
}
}
if (commentRendererElm && lc) {
return {
lc,
commentRendererElm
};
}
}
}
return null;
}
function lcSwapFuncA(targetLcId, currentLcId) {
let done = 0;
try {
let r1 = findLcComment(currentLcId).commentRendererElm;
let r2 = findLcComment(targetLcId).commentRendererElm;
if (typeof insp(r1).data.linkedCommentBadge === "object" && typeof insp(r2).data.linkedCommentBadge === "undefined") {
let p = Object.assign({}, insp(r1).data.linkedCommentBadge);
if (((p || 0).metadataBadgeRenderer || 0).trackingParams) {
delete p.metadataBadgeRenderer.trackingParams;
}
const v1 = findContentsRenderer(r1);
const v2 = findContentsRenderer(r2);
if (v1.parent === v2.parent && (v2.parent.nodeName === "YTD-COMMENTS" || v2.parent.nodeName === "YTD-ITEM-SECTION-RENDERER")) {
} else {
return false;
}
if (v2.index >= 0) {
if (v2.parent.nodeName === "YTD-COMMENT-REPLIES-RENDERER") {
if (lcSwapFuncB(targetLcId, currentLcId, p)) {
done = 1;
}
done = 1;
} else {
const v2pCnt = insp(v2.parent);
const v2Conents = (v2pCnt.data || 0).contents || 0;
if (!v2Conents)
;
v2pCnt.data = Object.assign({}, v2pCnt.data, {
contents: [].concat(
[v2Conents[v2.index]],
v2Conents.slice(0, v2.index),
v2Conents.slice(v2.index + 1)
)
});
if (lcSwapFuncB(targetLcId, currentLcId, p)) {
done = 1;
}
}
}
}
} catch (e) {
}
return done === 1;
}
function lcSwapFuncB(targetLcId, currentLcId, _p) {
let done = 0;
try {
let r1 = findLcComment(currentLcId).commentRendererElm;
let r1cnt = insp(r1);
let r2 = findLcComment(targetLcId).commentRendererElm;
let r2cnt = insp(r2);
const r1d = r1cnt.data;
let p = Object.assign({}, _p);
r1d.linkedCommentBadge = null;
delete r1d.linkedCommentBadge;
let q = Object.assign({}, r1d);
q.linkedCommentBadge = null;
delete q.linkedCommentBadge;
r1cnt.data = Object.assign({}, q);
r2cnt.data = Object.assign({}, r2cnt.data, { linkedCommentBadge: p });
done = 1;
} catch (e) {
}
return done === 1;
}
const loadStartFx = async (evt) => {
let media = (evt || 0).target || 0;
if (media.nodeName === "VIDEO" || media.nodeName === "AUDIO") {
} else
return;
const newMedia = media;
const media1 = common.getMediaElement(0);
const media2 = common.getMediaElements(2);
if (media1 !== null && media2.length > 0) {
if (newMedia !== media1 && media1.paused === false) {
if (isVideoPlaying(media1)) {
Promise.resolve(newMedia).then((video) => video.paused === false && video.pause()).catch(console.warn);
}
} else if (newMedia === media1) {
for (const s of media2) {
if (s.paused === false) {
Promise.resolve(s).then((s2) => s2.paused === false && s2.pause()).catch(console.warn);
break;
}
}
} else {
Promise.resolve(media1).then((video1) => video1.paused === false && video1.pause()).catch(console.warn);
}
}
};
const getBrowsableEndPoint = (req) => {
let valid = false;
let endpoint = req ? req.command : null;
if (endpoint && (endpoint.commandMetadata || 0).webCommandMetadata && endpoint.watchEndpoint) {
let videoId = endpoint.watchEndpoint.videoId;
let url = endpoint.commandMetadata.webCommandMetadata.url;
if (typeof videoId === "string" && typeof url === "string" && url.indexOf("lc=") > 0) {
let m = /^\/watch\?v=([\w_-]+)&lc=([\w_.-]+)$/.exec(url);
if (m && m[1] === videoId) {
let targetLc = findLcComment(m[2]);
let currentLc = targetLc ? findLcComment() : null;
if (targetLc && currentLc) {
let done = targetLc.lc === currentLc.lc ? 1 : lcSwapFuncA(targetLc.lc, currentLc.lc) ? 1 : 0;
if (done === 1) {
common.xReplaceState(history.state, url);
return;
}
}
}
}
}
if (endpoint && (endpoint.commandMetadata || 0).webCommandMetadata && endpoint.browseEndpoint && isChannelId(endpoint.browseEndpoint.browseId)) {
valid = true;
} else if (endpoint && (endpoint.browseEndpoint || endpoint.searchEndpoint) && !endpoint.urlEndpoint && !endpoint.watchEndpoint) {
if (endpoint.browseEndpoint && endpoint.browseEndpoint.browseId === "FEwhat_to_watch") {
const playerMedia = common.getMediaElement(1);
if (playerMedia && playerMedia.paused === false)
valid = true;
} else if (endpoint.commandMetadata && endpoint.commandMetadata.webCommandMetadata) {
let meta = endpoint.commandMetadata.webCommandMetadata;
if (meta && meta.url && meta.webPageType) {
valid = true;
}
}
}
if (!valid)
endpoint = null;
return endpoint;
};
const shouldUseMiniPlayer = () => {
const isSubTypeExist = document.querySelector(
"ytd-page-manager#page-manager > ytd-browse[page-subtype]"
);
if (isSubTypeExist)
return true;
const movie_player = [
...document.querySelectorAll("#movie_player")
].filter((e) => !e.closest("[hidden]"))[0];
if (movie_player) {
const media = qsOne(movie_player, "video[class], audio[class]");
if (media && media.currentTime > 3 && media.duration - media.currentTime > 3 && media.paused === false) {
return true;
}
}
return false;
};
const conditionFulfillment = (req) => {
const endpoint = req ? req.command : null;
if (!endpoint)
return;
if (endpoint && (endpoint.commandMetadata || 0).webCommandMetadata && endpoint.watchEndpoint) {
} else if (endpoint && (endpoint.commandMetadata || 0).webCommandMetadata && endpoint.browseEndpoint && isChannelId(endpoint.browseEndpoint.browseId)) {
} else if (endpoint && (endpoint.browseEndpoint || endpoint.searchEndpoint) && !endpoint.urlEndpoint && !endpoint.watchEndpoint) {
} else {
return false;
}
if (!shouldUseMiniPlayer())
return false;
if (pageType !== "watch")
return false;
if (!checkElementExist(
"ytd-watch-flexy #player button.ytp-miniplayer-button.ytp-button",
"[hidden]"
)) {
return false;
}
return true;
};
let u38 = 0;
const fixChannelAboutPopup = async (t38) => {
let promise = new PromiseExternal();
const f = () => {
promise && promise.resolve();
promise = null;
};
document.addEventListener("yt-navigate-finish", f, false);
await promise.then();
promise = null;
document.removeEventListener("yt-navigate-finish", f, false);
if (t38 !== u38)
return;
setTimeout(() => {
const currentAbout = [
...document.querySelectorAll("ytd-about-channel-renderer")
].filter((e) => !e.closest("[hidden]"))[0];
let okay = false;
if (!currentAbout)
okay = true;
else {
const popupContainer = currentAbout.closest("ytd-popup-container");
if (popupContainer) {
const cnt = insp(popupContainer);
let arr = null;
try {
arr = cnt.handleGetOpenedPopupsAction_();
} catch (e) {
}
if (arr && arr.length === 0)
okay = true;
} else {
okay = false;
}
}
if (okay) {
const descriptionModel = [
...document.querySelectorAll("yt-description-preview-view-model")
].filter((e) => !e.closest("[hidden]"))[0];
if (descriptionModel) {
const button = [
...descriptionModel.querySelectorAll("button")
].filter(
(e) => !e.closest("[hidden]") && `${e.textContent}`.trim().length > 0
)[0];
if (button) {
button.click();
}
}
}
}, 80);
};
const handleNavigateFactory2 = (handleNavigate) => {
return function(req) {
if (u38 > 1e9)
u38 = 9;
const t38 = ++u38;
const $this = this;
const $arguments = arguments;
let endpoint = null;
if (conditionFulfillment(req)) {
endpoint = getBrowsableEndPoint(req);
}
if (!endpoint || !shouldUseMiniPlayer())
return handleNavigate.apply($this, $arguments);
const ytdAppElm = document.querySelector("ytd-app");
const ytdAppCnt = insp(ytdAppElm);
let object = null;
try {
object = ytdAppCnt.data.response.currentVideoEndpoint.watchEndpoint || null;
} catch (e) {
object = null;
}
if (typeof object !== "object")
object = null;
const once = { once: true };
if (object !== null && !("playlistId" in object)) {
let wObject = mWeakRef(object);
const N = 3;
let count = 0;
Object.defineProperty(kRef(wObject) || {}, "playlistId", {
get() {
count++;
if (count === N) {
delete this.playlistId;
}
return "*";
},
set(value) {
delete this.playlistId;
this.playlistId = value;
},
enumerable: false,
configurable: true
});
let playlistClearout = null;
let timeoutid = 0;
Promise.race([
new Promise((r) => {
timeoutid = setTimeout(r, 4e3);
}),
new Promise((r) => {
playlistClearout = () => {
if (timeoutid > 0) {
clearTimeout(timeoutid);
timeoutid = 0;
}
r();
};
document.addEventListener(
"yt-page-type-changed",
playlistClearout,
once
);
})
]).then(() => {
if (timeoutid !== 0) {
playlistClearout && document.removeEventListener(
"yt-page-type-changed",
playlistClearout,
once
);
timeoutid = 0;
}
playlistClearout = null;
count = N - 1;
let object2 = kRef(wObject);
wObject = null;
return object2 ? object2.playlistId : null;
}).catch(console.warn);
}
if (!isLoadStartListened) {
isLoadStartListened = true;
document.addEventListener("loadstart", loadStartFx, true);
}
const endpointURL = `${endpoint?.commandMetadata?.webCommandMetadata?.url || ""}`;
if (endpointURL && endpointURL.endsWith("/about") && /\/channel\/UC[-_a-zA-Z0-9+=.]{22}\/about/.test(endpointURL)) {
fixChannelAboutPopup(t38);
}
handleNavigate.apply($this, $arguments);
};
};
return { handleNavigateFactory: handleNavigateFactory2 };
})();
const common = (() => {
let mediaModeLock = 0;
const _getMediaElement = (i) => {
if (mediaModeLock === 0) {
let e = document.querySelector(".video-stream.html5-main-video") || document.querySelector(
"#movie_player video, #movie_player audio"
) || document.querySelector("body video[src], body audio[src]");
if (e) {
if (e.nodeName === "VIDEO")
mediaModeLock = 1;
else if (e.nodeName === "AUDIO")
mediaModeLock = 2;
}
}
if (!mediaModeLock)
return null;
if (mediaModeLock === 1) {
switch (i) {
case 1:
return "ytd-player#ytd-player video[src]";
case 2:
return 'ytd-browse[role="main"] video[src]';
case 0:
default:
return "#movie_player video[src]";
}
} else if (mediaModeLock === 2) {
switch (i) {
case 1:
return "ytd-player#ytd-player audio.video-stream.html5-main-video[src]";
case 2:
return 'ytd-browse[role="main"] audio.video-stream.html5-main-video[src]';
case 0:
default:
return "#movie_player audio.video-stream.html5-main-video[src]";
}
}
return null;
};
return {
xReplaceState(s, u) {
try {
history.replaceState(s, "", u);
} catch (e) {
}
if (s.endpoint) {
try {
const ytdAppElm = document.querySelector("ytd-app");
const ytdAppCnt = insp(ytdAppElm);
ytdAppCnt.replaceState(s.endpoint, "", u);
} catch (e) {
}
}
},
getMediaElement(i) {
let s = _getMediaElement(i) || "";
if (s)
return document.querySelector(s);
return null;
},
getMediaElements(i) {
let s = _getMediaElement(i) || "";
if (s)
return document.querySelectorAll(s);
return [];
}
};
})();
let inPageRearrange = false;
let tmpLastVideoId = "";
const getCurrentVideoId = () => {
const ytdFlexyElm = elements.flexy;
const ytdFlexyCnt = insp(ytdFlexyElm);
if (ytdFlexyCnt && typeof ytdFlexyCnt.videoId === "string")
return ytdFlexyCnt.videoId;
if (ytdFlexyElm && typeof ytdFlexyElm.videoId === "string")
return ytdFlexyElm.videoId;
return "";
};
const holdInlineExpanderAlwaysExpanded = (inlineExpanderCnt) => {
if (inlineExpanderCnt.alwaysShowExpandButton === true)
inlineExpanderCnt.alwaysShowExpandButton = false;
if (typeof (inlineExpanderCnt.collapseLabel || 0) === "string")
inlineExpanderCnt.collapseLabel = "";
if (typeof (inlineExpanderCnt.expandLabel || 0) === "string")
inlineExpanderCnt.expandLabel = "";
if (inlineExpanderCnt.showCollapseButton === true)
inlineExpanderCnt.showCollapseButton = false;
if (inlineExpanderCnt.showExpandButton === true)
inlineExpanderCnt.showExpandButton = false;
if (inlineExpanderCnt.expandButton instanceof HTMLElement_) {
inlineExpanderCnt.expandButton = null;
inlineExpanderCnt.expandButton.remove();
}
};
const fixInlineExpanderMethods = (inlineExpanderCnt) => {
if (inlineExpanderCnt && !inlineExpanderCnt.__$$idncjk8487$$__) {
inlineExpanderCnt.__$$idncjk8487$$__ = true;
inlineExpanderCnt.updateTextOnSnippetTypeChange = function() {
};
inlineExpanderCnt.isResetMutation = true;
try {
inlineExpanderCnt.updateIsAttributedExpanded();
} catch (e) {
}
try {
inlineExpanderCnt.updateIsFormattedExpanded();
} catch (e) {
}
try {
inlineExpanderCnt.updateTextOnSnippetTypeChange();
} catch (e) {
}
try {
inlineExpanderCnt.updateStyles();
} catch (e) {
}
}
};
const fixInlineExpanderContent = () => {
const mainInfo = getMainInfo();
if (!mainInfo)
return;
const inlineExpanderElm = mainInfo.querySelector(
"ytd-text-inline-expander"
);
const inlineExpanderCnt = insp(inlineExpanderElm);
fixInlineExpanderMethods(inlineExpanderCnt);
};
const plugin = {
minibrowser: {
activated: false,
toUse: true,
activate() {
if (this.activated)
return;
const isPassiveArgSupport2 = typeof IntersectionObserver === "function";
if (!isPassiveArgSupport2)
return;
this.activated = true;
const ytdAppElm = document.querySelector("ytd-app");
const ytdAppCnt = insp(ytdAppElm);
if (!ytdAppCnt)
return;
const cProto = ytdAppCnt.constructor.prototype;
if (!cProto.handleNavigate)
return;
if (cProto.handleNavigate.__ma355__)
return;
cProto.handleNavigate = handleNavigateFactory(cProto.handleNavigate);
cProto.handleNavigate.__ma355__ = 1;
}
},
autoExpandInfoDesc: {
activated: false,
toUse: false,
mo: null,
promiseReady: new PromiseExternal(),
moFn(lockId) {
if (lockGet["autoExpandInfoDescAttrAsyncLock"] !== lockId)
return;
const mainInfo = getMainInfo();
if (!mainInfo)
return;
switch (((mainInfo || 0).nodeName || "").toLowerCase()) {
case "ytd-expander":
if (mainInfo.hasAttribute000("collapsed")) {
let success = false;
try {
insp(mainInfo).handleMoreTap(new Event("tap"));
success = true;
} catch (e) {
}
if (success)
mainInfo.setAttribute111("tyt-no-less-btn", "");
}
break;
case "ytd-expandable-video-description-body-renderer":
const inlineExpanderElm = mainInfo.querySelector(
"ytd-text-inline-expander"
);
const inlineExpanderCnt = insp(inlineExpanderElm);
if (inlineExpanderCnt && inlineExpanderCnt.isExpanded === false) {
inlineExpanderCnt.isExpanded = true;
inlineExpanderCnt.isExpandedChanged();
}
break;
}
},
activate() {
if (this.activated)
return;
this.moFn = this.moFn.bind(this);
this.mo = new MutationObserver(() => {
Promise.resolve(lockSet["autoExpandInfoDescAttrAsyncLock"]).then(this.moFn).catch(console.warn);
});
this.activated = true;
this.promiseReady.resolve();
},
async onMainInfoSet(mainInfo) {
await this.promiseReady.then();
if (mainInfo.nodeName.toLowerCase() === "ytd-expander") {
this.mo.observe(mainInfo, {
attributes: true,
attributeFilter: ["collapsed", "attr-8ifv7"]
});
} else {
this.mo.observe(mainInfo, {
attributes: true,
attributeFilter: ["attr-8ifv7"]
});
}
mainInfo.incAttribute111("attr-8ifv7");
}
},
fullChannelNameOnHover: {
activated: false,
toUse: true,
mo: null,
ro: null,
promiseReady: new PromiseExternal(),
checkResize: 0,
mouseEnterFn(evt) {
const target = evt ? evt.target : null;
if (!(target instanceof HTMLElement_))
return;
const metaDataElm = target.closest("ytd-watch-metadata");
metaDataElm.classList.remove("tyt-metadata-hover-resized");
this.checkResize = Date.now() + 300;
metaDataElm.classList.add("tyt-metadata-hover");
},
mouseLeaveFn(evt) {
const target = evt ? evt.target : null;
if (!(target instanceof HTMLElement_))
return;
const metaDataElm = target.closest("ytd-watch-metadata");
metaDataElm.classList.remove("tyt-metadata-hover-resized");
metaDataElm.classList.remove("tyt-metadata-hover");
},
moFn(lockId) {
if (lockGet["fullChannelNameOnHoverAttrAsyncLock"] !== lockId)
return;
const uploadInfo = document.querySelector(
"#primary.ytd-watch-flexy ytd-watch-metadata #upload-info"
);
if (!uploadInfo)
return;
const evtOpt = { passive: true, capture: false };
uploadInfo.removeEventListener(
"pointerenter",
this.mouseEnterFn,
evtOpt
);
uploadInfo.removeEventListener(
"pointerleave",
this.mouseLeaveFn,
evtOpt
);
uploadInfo.addEventListener(
"pointerenter",
this.mouseEnterFn,
evtOpt
);
uploadInfo.addEventListener(
"pointerleave",
this.mouseLeaveFn,
evtOpt
);
},
async onNavigateFinish() {
await this.promiseReady.then();
const uploadInfo = document.querySelector(
"#primary.ytd-watch-flexy ytd-watch-metadata #upload-info"
);
if (!uploadInfo)
return;
this.mo.observe(uploadInfo, {
attributes: true,
attributeFilter: ["hidden", "attr-3wb0k"]
});
uploadInfo.incAttribute111("attr-3wb0k");
this.ro.observe(uploadInfo);
},
activate() {
if (this.activated)
return;
const isPassiveArgSupport2 = typeof IntersectionObserver === "function";
if (!isPassiveArgSupport2)
return;
this.activated = true;
this.mouseEnterFn = this.mouseEnterFn.bind(this);
this.mouseLeaveFn = this.mouseLeaveFn.bind(this);
this.moFn = this.moFn.bind(this);
this.mo = new MutationObserver(() => {
Promise.resolve(lockSet["fullChannelNameOnHoverAttrAsyncLock"]).then(this.moFn).catch(console.warn);
});
this.ro = new ResizeObserver((mutations) => {
if (Date.now() > this.checkResize)
return;
for (const mutation of mutations) {
const uploadInfo = mutation.target;
if (uploadInfo && mutation.contentRect.width > 0 && mutation.contentRect.height > 0) {
const metaDataElm = uploadInfo.closest("ytd-watch-metadata");
if (metaDataElm.classList.contains("tyt-metadata-hover")) {
metaDataElm.classList.add("tyt-metadata-hover-resized");
}
break;
}
}
});
this.promiseReady.resolve();
}
}
};
if (sessionStorage.__$$tmp_UseAutoExpandInfoDesc$$__)
plugin.autoExpandInfoDesc.toUse = true;
const __attachedSymbol__ = Symbol();
const makeInitAttached = (tag) => {
const inPageRearrange_ = inPageRearrange;
inPageRearrange = false;
for (const elm of document.querySelectorAll(`${tag}`)) {
const cnt = insp(elm) || 0;
if (typeof cnt.attached498 === "function" && !elm[__attachedSymbol__])
Promise.resolve(elm).then(eventMap[`${tag}::attached`]).catch(console.warn);
}
inPageRearrange = inPageRearrange_;
};
const getGeneralChatElement = async () => {
for (let i = 2; i-- > 0; ) {
let t = document.querySelector(
"#columns.style-scope.ytd-watch-flexy ytd-live-chat-frame#chat"
);
if (t instanceof Element)
return t;
if (i > 0) {
await delayPn(200);
}
}
return null;
};
const nsTemplateObtain = () => {
let nsTemplate = document.querySelector(
"ytd-watch-flexy noscript[ns-template]"
);
if (!nsTemplate) {
nsTemplate = document.createElement("noscript");
nsTemplate.setAttribute("ns-template", "");
document.querySelector("ytd-watch-flexy").appendChild(nsTemplate);
}
return nsTemplate;
};
const isPageDOM = (elm, selector) => {
if (!elm || !(elm instanceof Element) || !elm.nodeName)
return false;
if (!elm.closest(selector))
return false;
if (elm.isConnected !== true)
return false;
return true;
};
const invalidFlexyParent = (hostElement2) => {
if (hostElement2 instanceof HTMLElement) {
const hasFlexyParent = HTMLElement.prototype.closest.call(
hostElement2,
"ytd-watch-flexy"
);
if (!hasFlexyParent)
return true;
const currentFlexy = elements.flexy;
if (currentFlexy && currentFlexy !== hasFlexyParent)
return true;
}
return false;
};
const eventMap = {
ceHack: () => {
mLoaded.flag |= 2;
document.documentElement.setAttribute111(
"tabview-loaded",
mLoaded.makeString()
);
retrieveCE("ytd-watch-flexy").then(eventMap["ytd-watch-flexy::defined"]).catch(console.warn);
retrieveCE("ytd-expander").then(eventMap["ytd-expander::defined"]).catch(console.warn);
retrieveCE("ytd-watch-next-secondary-results-renderer").then(eventMap["ytd-watch-next-secondary-results-renderer::defined"]).catch(console.warn);
retrieveCE("ytd-comments-header-renderer").then(eventMap["ytd-comments-header-renderer::defined"]).catch(console.warn);
retrieveCE("ytd-live-chat-frame").then(eventMap["ytd-live-chat-frame::defined"]).catch(console.warn);
retrieveCE("ytd-comments").then(eventMap["ytd-comments::defined"]).catch(console.warn);
retrieveCE("ytd-engagement-panel-section-list-renderer").then(eventMap["ytd-engagement-panel-section-list-renderer::defined"]).catch(console.warn);
retrieveCE("ytd-watch-metadata").then(eventMap["ytd-watch-metadata::defined"]).catch(console.warn);
retrieveCE("ytd-playlist-panel-renderer").then(eventMap["ytd-playlist-panel-renderer::defined"]).catch(console.warn);
retrieveCE("ytd-expandable-video-description-body-renderer").then(
eventMap["ytd-expandable-video-description-body-renderer::defined"]
).catch(console.warn);
},
fixForTabDisplay: (isResize) => {
bFixForResizedTabLater = false;
for (const element of document.querySelectorAll("[io-intersected]")) {
const cnt = insp(element);
if (element instanceof HTMLElement_ && typeof cnt.calculateCanCollapse === "function") {
try {
cnt.calculateCanCollapse(true);
} catch (e) {
}
}
}
if (!isResize) {
for (const element of document.querySelectorAll(
"ytd-video-description-infocards-section-renderer, yt-chip-cloud-renderer, ytd-horizontal-card-list-renderer"
)) {
const cnt = insp(element);
if (element instanceof HTMLElement_ && typeof cnt.notifyResize === "function") {
try {
cnt.notifyResize();
} catch (e) {
}
}
}
}
},
"ytd-watch-flexy::defined": (cProto) => {
if (!cProto.updateChatLocation498 && typeof cProto.updateChatLocation === "function" && cProto.updateChatLocation.length === 0) {
cProto.updateChatLocation498 = cProto.updateChatLocation;
cProto.updateChatLocation = updateChatLocation498;
}
},
"ytd-watch-next-secondary-results-renderer::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-watch-next-secondary-results-renderer::attached"]
).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-watch-next-secondary-results-renderer::detached"]
).catch(console.warn);
return this.detached498();
};
}
makeInitAttached("ytd-watch-next-secondary-results-renderer");
},
"ytd-watch-next-secondary-results-renderer::attached": (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (hostElement2 instanceof HTMLElement_ && hostElement2.matches(
"#columns #related ytd-watch-next-secondary-results-renderer"
) && !hostElement2.matches(
"#right-tabs ytd-watch-next-secondary-results-renderer, [hidden] ytd-watch-next-secondary-results-renderer"
)) {
elements.related = hostElement2.closest("#related");
hostElement2.setAttribute111("tyt-videos-list", "");
}
},
"ytd-watch-next-secondary-results-renderer::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("tyt-videos-list")) {
elements.related = null;
hostElement2.removeAttribute000("tyt-videos-list");
}
},
settingCommentsVideoId: (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
const cnt = insp(hostElement2);
const commentsArea = elements.comments;
if (commentsArea !== hostElement2 || hostElement2.isConnected !== true || cnt.isAttached !== true || !cnt.data || cnt.hidden !== false)
return;
const ytdFlexyElm = elements.flexy;
const ytdFlexyCnt = ytdFlexyElm ? insp(ytdFlexyElm) : null;
if (ytdFlexyCnt && ytdFlexyCnt.videoId) {
hostElement2.setAttribute111(
"tyt-comments-video-id",
ytdFlexyCnt.videoId
);
} else {
hostElement2.removeAttribute000("tyt-comments-video-id");
}
},
checkCommentsShouldBeHidden: (lockId) => {
if (lockGet["checkCommentsShouldBeHiddenLock"] !== lockId)
return;
const commentsArea = elements.comments;
const ytdFlexyElm = elements.flexy;
if (commentsArea && ytdFlexyElm && !commentsArea.hasAttribute000("hidden")) {
const ytdFlexyCnt = insp(ytdFlexyElm);
if (typeof ytdFlexyCnt.videoId === "string") {
const commentsVideoId = commentsArea.getAttribute(
"tyt-comments-video-id"
);
if (commentsVideoId && commentsVideoId !== ytdFlexyCnt.videoId) {
commentsArea.setAttribute111("hidden", "");
}
}
}
},
"ytd-comments::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-comments::attached"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-comments::detached"]).catch(console.warn);
return this.detached498();
};
}
cProto._createPropertyObserver("data", "_dataChanged498", void 0);
cProto._dataChanged498 = function() {
Promise.resolve(this.hostElement).then(eventMap["ytd-comments::_dataChanged498"]).catch(console.warn);
};
makeInitAttached("ytd-comments");
},
"ytd-comments::_dataChanged498": (hostElement2) => {
if (!hostElement2.hasAttribute000("tyt-comments-area"))
return;
let commentsDataStatus = 0;
const cnt = insp(hostElement2);
const data = cnt ? cnt.data : null;
const contents = data ? data.contents : null;
if (data) {
if (contents && contents.length === 1 && contents[0].messageRenderer) {
commentsDataStatus = 2;
}
if (contents && contents.length > 1 && contents[0].commentThreadRenderer) {
commentsDataStatus = 1;
}
}
if (commentsDataStatus) {
hostElement2.setAttribute111(
"tyt-comments-data-status",
commentsDataStatus
);
} else {
hostElement2.removeAttribute000("tyt-comments-data-status");
}
Promise.resolve(hostElement2).then(eventMap["settingCommentsVideoId"]).catch(console.warn);
},
"ytd-comments::attached": async (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (!hostElement2 || hostElement2.id !== "comments")
return;
elements.comments = hostElement2;
Promise.resolve(hostElement2).then(eventMap["settingCommentsVideoId"]).catch(console.warn);
aoComment.observe(hostElement2, { attributes: true });
hostElement2.setAttribute111("tyt-comments-area", "");
const lockId = lockSet["rightTabReadyLock02"];
await rightTabsProvidedPromise.then();
if (lockGet["rightTabReadyLock02"] !== lockId)
return;
if (elements.comments !== hostElement2)
return;
if (hostElement2.isConnected === false)
return;
if (hostElement2 && !hostElement2.closest("#right-tabs")) {
document.querySelector("#tab-comments").assignChildern111(null, hostElement2, null);
} else {
const shouldTabVisible = elements.comments && elements.comments.closest("#tab-comments") && !elements.comments.closest("[hidden]");
document.querySelector('[tyt-tab-content="#tab-comments"]').classList.toggle("tab-btn-hidden", !shouldTabVisible);
Promise.resolve(lockSet["removeKeepCommentsScrollerLock"]).then(removeKeepCommentsScroller).catch(console.warn);
}
},
"ytd-comments::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("tyt-comments-area")) {
hostElement2.removeAttribute000("tyt-comments-area");
aoComment.disconnect();
aoComment.takeRecords();
elements.comments = null;
document.querySelector('[tyt-tab-content="#tab-comments"]').classList.add("tab-btn-hidden");
Promise.resolve(lockSet["removeKeepCommentsScrollerLock"]).then(removeKeepCommentsScroller).catch(console.warn);
}
},
"ytd-comments-header-renderer::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-comments-header-renderer::attached"]).catch(console.warn);
Promise.resolve(this.hostElement).then(eventMap["ytd-comments-header-renderer::dataChanged"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-comments-header-renderer::detached"]).catch(console.warn);
return this.detached498();
};
}
if (!cProto.dataChanged498 && typeof cProto.dataChanged === "function") {
cProto.dataChanged498 = cProto.dataChanged;
cProto.dataChanged = function() {
Promise.resolve(this.hostElement).then(eventMap["ytd-comments-header-renderer::dataChanged"]).catch(console.warn);
return this.dataChanged498();
};
}
makeInitAttached("ytd-comments-header-renderer");
},
"ytd-comments-header-renderer::attached": (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (!hostElement2 || !hostElement2.classList.contains("ytd-item-section-renderer"))
return;
const targetElement = document.querySelector(
"[tyt-comments-area] ytd-comments-header-renderer"
);
if (hostElement2 === targetElement) {
hostElement2.setAttribute111("tyt-comments-header-field", "");
} else {
const parentNode = hostElement2.parentNode;
if (parentNode instanceof HTMLElement_ && parentNode.querySelector("[tyt-comments-header-field]")) {
hostElement2.setAttribute111("tyt-comments-header-field", "");
}
}
},
"ytd-comments-header-renderer::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("field-of-cm-count")) {
const cmCount = document.querySelector("#tyt-cm-count");
if (cmCount) {
cmCount.textContent = "";
hostElement2.removeAttribute000("field-of-cm-count");
}
}
if (hostElement2.hasAttribute000("tyt-comments-header-field")) {
hostElement2.removeAttribute000("tyt-comments-header-field");
}
},
"ytd-comments-header-renderer::dataChanged": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
const ytdFlexyElm = elements.flexy;
let b = false;
const cnt = insp(hostElement2);
if (cnt && hostElement2.closest("#tab-comments") && document.querySelector(
"#tab-comments ytd-comments-header-renderer"
) === hostElement2) {
b = true;
} else if (hostElement2 instanceof HTMLElement_ && hostElement2.parentNode instanceof HTMLElement_ && hostElement2.parentNode.querySelector("[tyt-comments-header-field]")) {
b = true;
}
if (b) {
hostElement2.setAttribute111("tyt-comments-header-field", "");
ytdFlexyElm && ytdFlexyElm.removeAttribute000("tyt-comment-disabled");
}
if (hostElement2.hasAttribute000("tyt-comments-header-field") && hostElement2.isConnected === true) {
const data = cnt.data;
let ez = "";
if (data.commentsCount && data.commentsCount.runs && data.commentsCount.runs.length >= 1) {
let max = -1;
const z = data.commentsCount.runs.map((e) => {
let c = e.text.replace(/\D+/g, "").length;
if (c > max)
max = c;
return [e.text, c];
}).filter((a) => a[1] === max);
if (z.length >= 1) {
ez = z[0][0];
}
} else if (data.countText && data.countText.runs && data.countText.runs.length >= 1) {
let max = -1;
const z = data.countText.runs.map((e) => {
let c = e.text.replace(/\D+/g, "").length;
if (c > max)
max = c;
return [e.text, c];
}).filter((a) => a[1] === max);
if (z.length >= 1) {
ez = z[0][0];
}
}
const cmCount = document.querySelector("#tyt-cm-count");
if (ez) {
hostElement2.setAttribute111("field-of-cm-count", "");
cmCount && (cmCount.textContent = ez.trim());
} else {
hostElement2.removeAttribute000("field-of-cm-count");
cmCount && (cmCount.textContent = "");
}
}
},
"ytd-expander::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-expander::attached"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-expander::detached"]).catch(console.warn);
return this.detached498();
};
}
if (!cProto.calculateCanCollapse498 && typeof cProto.calculateCanCollapse === "function") {
cProto.calculateCanCollapse498 = cProto.calculateCanCollapse;
cProto.calculateCanCollapse = funcCanCollapse;
}
if (!cProto.childrenChanged498 && typeof cProto.childrenChanged === "function") {
cProto.childrenChanged498 = cProto.childrenChanged;
cProto.childrenChanged = function() {
Promise.resolve(this.hostElement).then(eventMap["ytd-expander::childrenChanged"]).catch(console.warn);
return this.childrenChanged498();
};
}
makeInitAttached("ytd-expander");
},
"ytd-expander::childrenChanged": (hostElement2) => {
if (hostElement2 instanceof Node && hostElement2.hasAttribute000("hidden") && hostElement2.hasAttribute000("tyt-main-info") && hostElement2.firstElementChild) {
hostElement2.removeAttribute("hidden");
}
},
"ytd-expandable-video-description-body-renderer::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-expandable-video-description-body-renderer::attached"]
).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-expandable-video-description-body-renderer::detached"]
).catch(console.warn);
return this.detached498();
};
}
makeInitAttached("ytd-expandable-video-description-body-renderer");
},
"ytd-expandable-video-description-body-renderer::attached": async (hostElement2) => {
if (hostElement2 instanceof HTMLElement_ && isPageDOM(hostElement2, "[tyt-info-renderer]") && !hostElement2.matches("[tyt-main-info]")) {
elements.infoExpander = hostElement2;
infoExpanderElementProvidedPromise.resolve();
hostElement2.setAttribute111("tyt-main-info", "");
if (plugin.autoExpandInfoDesc.toUse) {
plugin.autoExpandInfoDesc.onMainInfoSet(hostElement2);
}
const lockId = lockSet["rightTabReadyLock03"];
await rightTabsProvidedPromise.then();
if (lockGet["rightTabReadyLock03"] !== lockId)
return;
if (elements.infoExpander !== hostElement2)
return;
if (hostElement2.isConnected === false)
return;
elements.infoExpander.classList.add("tyt-main-info");
const infoExpander = elements.infoExpander;
const inlineExpanderElm = infoExpander.querySelector(
"ytd-text-inline-expander"
);
if (inlineExpanderElm) {
const mo = new MutationObserver(() => {
const p = document.querySelector(
"#tab-info ytd-text-inline-expander"
);
sessionStorage.__$$tmp_UseAutoExpandInfoDesc$$__ = p && p.hasAttribute("is-expanded") ? "1" : "";
if (p)
fixInlineExpanderContent();
});
mo.observe(inlineExpanderElm, {
attributes: ["is-expanded", "attr-6v8qu", "hidden"],
subtree: true
});
hostElement2.incAttribute111("attr-6v8qu");
const cnt = insp(inlineExpanderElm);
if (cnt) {
try {
cnt.updateIsAttributedExpanded();
} catch (e) {
}
try {
cnt.updateIsFormattedExpanded();
} catch (e) {
}
try {
cnt.updateTextOnSnippetTypeChange();
} catch (e) {
}
try {
cnt.updateStyles();
} catch (e) {
}
}
}
if (infoExpander && !infoExpander.closest("#right-tabs")) {
document.querySelector("#tab-info").assignChildern111(null, infoExpander, null);
} else {
if (document.querySelector('[tyt-tab-content="#tab-info"]')) {
const shouldTabVisible = elements.infoExpander && elements.infoExpander.closest("#tab-info");
document.querySelector('[tyt-tab-content="#tab-info"]').classList.toggle("tab-btn-hidden", !shouldTabVisible);
}
}
Promise.resolve(lockSet["infoFixLock"]).then(infoFix).catch(console.warn);
}
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (isPageDOM(hostElement2, "#tab-info [tyt-main-info]")) {
} else if (!hostElement2.closest("#tab-info")) {
const bodyRenderer = hostElement2;
let bodyRendererNew = document.querySelector(
"ytd-expandable-video-description-body-renderer[tyt-info-renderer]"
);
if (!bodyRendererNew) {
bodyRendererNew = document.createElement(
"ytd-expandable-video-description-body-renderer"
);
bodyRendererNew.setAttribute("tyt-info-renderer", "");
nsTemplateObtain().appendChild(bodyRendererNew);
}
const cnt = insp(bodyRendererNew);
cnt.data = Object.assign({}, insp(bodyRenderer).data);
const inlineExpanderElm = bodyRendererNew.querySelector(
"ytd-text-inline-expander"
);
const inlineExpanderCnt = insp(inlineExpanderElm);
fixInlineExpanderMethods(inlineExpanderCnt);
elements.infoExpanderRendererBack = bodyRenderer;
elements.infoExpanderRendererFront = bodyRendererNew;
bodyRenderer.setAttribute("tyt-info-renderer-back", "");
bodyRendererNew.setAttribute("tyt-info-renderer-front", "");
}
},
"ytd-expandable-video-description-body-renderer::detached": async () => {
if (!(hostElement instanceof HTMLElement_) || hostElement.closest("noscript"))
return;
if (hostElement.isConnected !== false)
return;
if (hostElement.hasAttribute000("tyt-main-info")) {
elements.infoExpander = null;
hostElement.removeAttribute000("tyt-main-info");
}
},
"ytd-expander::attached": async (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (hostElement2 instanceof HTMLElement_ && hostElement2.matches(
"[tyt-comments-area] #contents ytd-expander#expander"
) && !hostElement2.matches("[hidden] ytd-expander#expander")) {
hostElement2.setAttribute111("tyt-content-comment-entry", "");
ioComment.observe(hostElement2);
}
},
"ytd-expander::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("tyt-content-comment-entry")) {
ioComment.unobserve(hostElement2);
hostElement2.removeAttribute000("tyt-content-comment-entry");
} else if (hostElement2.hasAttribute000("tyt-main-info")) {
elements.infoExpander = null;
hostElement2.removeAttribute000("tyt-main-info");
}
},
"ytd-live-chat-frame::defined": (cProto) => {
let lastDomAction = 0;
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
lastDomAction = Date.now();
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-live-chat-frame::attached"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
lastDomAction = Date.now();
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-live-chat-frame::detached"]).catch(console.warn);
return this.detached498();
};
}
if (typeof cProto.urlChanged === "function" && !cProto.urlChanged66 && !cProto.urlChangedAsync12 && cProto.urlChanged.length === 0) {
cProto.urlChanged66 = cProto.urlChanged;
let ath = 0;
cProto.urlChangedAsync12 = async function() {
const t = ath = (ath & 1073741823) + 1;
const chatframe = this.chatframe || (this.$ || 0).chatframe || 0;
if (chatframe instanceof HTMLIFrameElement) {
if (chatframe.contentDocument === null) {
await Promise.resolve("#").catch(console.warn);
if (t !== ath)
return;
}
const p1 = new Promise(
(resolve) => setTimeout_(resolve, 706)
).catch(console.warn);
const p2 = new Promise((resolve) => {
new IntersectionObserver((entries, observer) => {
for (const entry of entries) {
const rect = entry.boundingClientRect || 0;
if (rect.width > 0 && rect.height > 0) {
observer.disconnect();
resolve("#");
break;
}
}
}).observe(chatframe);
}).catch(console.warn);
await Promise.race([p1, p2]);
if (t !== ath)
return;
}
this.urlChanged66();
};
cProto.urlChanged = function() {
this.urlChangedAsync12();
};
}
makeInitAttached("ytd-live-chat-frame");
},
"ytd-live-chat-frame::attached": async (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (!hostElement2 || hostElement2.id !== "chat")
return;
const lockId = lockSet["ytdLiveAttachedLock"];
const chatElem = await getGeneralChatElement();
if (lockGet["ytdLiveAttachedLock"] !== lockId)
return;
if (chatElem === hostElement2) {
elements.chat = chatElem;
aoChat.observe(chatElem, { attributes: true });
const isFlexyReady = elements.flexy instanceof Element;
chatElem.setAttribute111(
"tyt-active-chat-frame",
isFlexyReady ? "CF" : "C"
);
const chatContainer = chatElem ? chatElem.closest("#chat-container") || chatElem : null;
if (chatContainer && !chatContainer.hasAttribute000("tyt-chat-container")) {
for (const p of document.querySelectorAll("[tyt-chat-container]")) {
p.removeAttribute000("[tyt-chat-container]");
}
chatContainer.setAttribute111("tyt-chat-container", "");
}
Promise.resolve(lockSet["layoutFixLock"]).then(layoutFix);
} else {
}
},
"ytd-live-chat-frame::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("tyt-active-chat-frame")) {
aoChat.disconnect();
aoChat.takeRecords();
hostElement2.removeAttribute000("tyt-active-chat-frame");
elements.chat = null;
const ytdFlexyElm = elements.flexy;
if (ytdFlexyElm) {
ytdFlexyElm.removeAttribute000("tyt-chat-collapsed");
ytdFlexyElm.setAttribute111("tyt-chat", "");
}
}
},
"ytd-engagement-panel-section-list-renderer::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-engagement-panel-section-list-renderer::attached"]
).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(
eventMap["ytd-engagement-panel-section-list-renderer::detached"]
).catch(console.warn);
return this.detached498();
};
}
makeInitAttached("ytd-engagement-panel-section-list-renderer");
},
"ytd-engagement-panel-section-list-renderer::bindTarget": (hostElement2) => {
if (hostElement2.matches(
"#panels.ytd-watch-flexy > ytd-engagement-panel-section-list-renderer[target-id][visibility]"
)) {
hostElement2.setAttribute111("tyt-egm-panel", "");
Promise.resolve(lockSet["updateEgmPanelsLock"]).then(updateEgmPanels).catch(console.warn);
aoEgmPanels.observe(hostElement2, {
attributes: true,
attributeFilter: ["visibility", "hidden"]
});
}
},
"ytd-engagement-panel-section-list-renderer::attached": (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (!hostElement2.matches(
"#panels.ytd-watch-flexy > ytd-engagement-panel-section-list-renderer"
))
return;
if (hostElement2.hasAttribute000("target-id") && hostElement2.hasAttribute000("visibility")) {
Promise.resolve(hostElement2).then(
eventMap["ytd-engagement-panel-section-list-renderer::bindTarget"]
).catch(console.warn);
} else {
hostElement2.setAttribute000("tyt-egm-panel-jclmd", "");
moEgmPanelReady.observe(hostElement2, {
attributes: true,
attributeFilter: ["visibility", "target-id"]
});
}
},
"ytd-engagement-panel-section-list-renderer::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
if (hostElement2.hasAttribute000("tyt-egm-panel")) {
hostElement2.removeAttribute000("tyt-egm-panel");
Promise.resolve(lockSet["updateEgmPanelsLock"]).then(updateEgmPanels).catch(console.warn);
} else if (hostElement2.hasAttribute000("tyt-egm-panel-jclmd")) {
hostElement2.removeAttribute000("tyt-egm-panel-jclmd");
moEgmPanelReadyClearFn();
}
},
"ytd-watch-metadata::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-watch-metadata::attached"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-watch-metadata::detached"]).catch(console.warn);
return this.detached498();
};
}
makeInitAttached("ytd-watch-metadata");
},
"ytd-watch-metadata::attached": (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
if (plugin.fullChannelNameOnHover.activated)
plugin.fullChannelNameOnHover.onNavigateFinish();
},
"ytd-watch-metadata::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
},
"ytd-playlist-panel-renderer::defined": (cProto) => {
if (!cProto.attached498 && typeof cProto.attached === "function") {
cProto.attached498 = cProto.attached;
cProto.attached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-playlist-panel-renderer::attached"]).catch(console.warn);
return this.attached498();
};
}
if (!cProto.detached498 && typeof cProto.detached === "function") {
cProto.detached498 = cProto.detached;
cProto.detached = function() {
if (!inPageRearrange)
Promise.resolve(this.hostElement).then(eventMap["ytd-playlist-panel-renderer::detached"]).catch(console.warn);
return this.detached498();
};
}
makeInitAttached("ytd-playlist-panel-renderer");
},
"ytd-playlist-panel-renderer::attached": (hostElement2) => {
if (invalidFlexyParent(hostElement2))
return;
if (hostElement2 instanceof Element)
hostElement2[__attachedSymbol__] = true;
if (!(hostElement2 instanceof HTMLElement_) || !(hostElement2.classList.length > 0) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== true)
return;
elements.playlist = hostElement2;
aoPlayList.observe(hostElement2, {
attributes: true,
attributeFilter: ["hidden", "collapsed", "attr-1y6nu"]
});
hostElement2.incAttribute111("attr-1y6nu");
},
"ytd-playlist-panel-renderer::detached": (hostElement2) => {
if (!(hostElement2 instanceof HTMLElement_) || hostElement2.closest("noscript"))
return;
if (hostElement2.isConnected !== false)
return;
},
_yt_playerProvided: () => {
mLoaded.flag |= 4;
document.documentElement.setAttribute111(
"tabview-loaded",
mLoaded.makeString()
);
},
relatedElementProvided: (target) => {
if (target.closest("[hidden]"))
return;
elements.related = target;
videosElementProvidedPromise.resolve();
},
onceInfoExpanderElementProvidedPromised: () => {
const ytdFlexyElm = elements.flexy;
if (ytdFlexyElm) {
ytdFlexyElm.setAttribute111("hide-default-text-inline-expander", "");
}
},
refreshSecondaryInner: (lockId) => {
if (lockGet["refreshSecondaryInnerLock"] !== lockId)
return;
const ytdFlexyElm = elements.flexy;
if (ytdFlexyElm && ytdFlexyElm.matches(
"ytd-watch-flexy[theater][flexy][full-bleed-player]:not([full-bleed-no-max-width-columns])"
)) {
ytdFlexyElm.setAttribute111("full-bleed-no-max-width-columns", "");
}
const related = elements.related;
if (related && related.isConnected && !related.closest("#right-tabs #tab-videos")) {
document.querySelector("#tab-videos").assignChildern111(null, related, null);
}
const infoExpander = elements.infoExpander;
if (infoExpander && infoExpander.isConnected && !infoExpander.closest("#right-tabs #tab-info")) {
document.querySelector("#tab-info").assignChildern111(null, infoExpander, null);
} else {
}
const commentsArea = elements.comments;
if (commentsArea) {
const isConnected = commentsArea.isConnected;
if (isConnected && !commentsArea.closest("#right-tabs #tab-comments")) {
const tab = document.querySelector("#tab-comments");
tab.assignChildern111(null, commentsArea, null);
} else {
}
}
},
"yt-navigate-finish": (evt) => {
const ytdAppElm = document.querySelector(
"ytd-page-manager#page-manager.style-scope.ytd-app"
);
const ytdAppCnt = insp(ytdAppElm);
pageType = ytdAppCnt ? (ytdAppCnt.data || 0).page : null;
if (!document.querySelector("ytd-watch-flexy #player"))
return;
const flexyArr = [
...document.querySelectorAll("ytd-watch-flexy")
].filter((e) => !e.closest("[hidden]") && e.querySelector("#player"));
if (flexyArr.length === 1) {
elements.flexy = flexyArr[0];
if (isRightTabsInserted) {
Promise.resolve(lockSet["refreshSecondaryInnerLock"]).then(eventMap["refreshSecondaryInner"]).catch(console.warn);
Promise.resolve(lockSet["removeKeepCommentsScrollerLock"]).then(removeKeepCommentsScroller).catch(console.warn);
} else {
navigateFinishedPromise.resolve();
if (plugin.minibrowser.toUse)
plugin.minibrowser.activate();
if (plugin.autoExpandInfoDesc.toUse)
plugin.autoExpandInfoDesc.activate();
if (plugin.fullChannelNameOnHover.toUse)
plugin.fullChannelNameOnHover.activate();
}
const chat = elements.chat;
if (chat instanceof Element) {
chat.setAttribute111("tyt-active-chat-frame", "CF");
}
const infoExpander = elements.infoExpander;
if (infoExpander && infoExpander.closest("#right-tabs")) {
Promise.resolve(lockSet["infoFixLock"]).then(infoFix).catch(console.warn);
}
Promise.resolve(lockSet["layoutFixLock"]).then(layoutFix);
if (plugin.fullChannelNameOnHover.activated)
plugin.fullChannelNameOnHover.onNavigateFinish();
}
},
onceInsertRightTabs: () => {
const related = elements.related;
let rightTabs = document.querySelector("#right-tabs");
if (!document.querySelector("#right-tabs") && related) {
getLangForPage();
let docTmp = document.createElement("template");
docTmp.innerHTML = createHTML(getTabsHTML());
let newElm = docTmp.content.firstElementChild;
if (newElm !== null) {
inPageRearrange = true;
related.parentNode.insertBefore000(newElm, related);
inPageRearrange = false;
}
rightTabs = newElm;
rightTabs.querySelector('[tyt-tab-content="#tab-comments"]').classList.add("tab-btn-hidden");
const secondaryWrapper = document.createElement("secondary-wrapper");
const secondaryInner = document.querySelector(
"#secondary-inner.style-scope.ytd-watch-flexy"
);
inPageRearrange = true;
secondaryWrapper.replaceChildren000(...secondaryInner.childNodes);
secondaryInner.insertBefore000(
secondaryWrapper,
secondaryInner.firstChild
);
inPageRearrange = false;
rightTabs.querySelector("#material-tabs").addEventListener("click", eventMap["tabs-btn-click"], true);
inPageRearrange = true;
if (!rightTabs.closest("secondary-wrapper"))
secondaryWrapper.appendChild000(rightTabs);
inPageRearrange = false;
}
if (rightTabs) {
isRightTabsInserted = true;
const ioTabBtns = new IntersectionObserver(
(entries) => {
for (const entry of entries) {
const rect = entry.boundingClientRect;
entry.target.classList.toggle(
"tab-btn-visible",
rect.width && rect.height
);
}
},
{ rootMargin: "0px" }
);
for (const btn of document.querySelectorAll(
".tab-btn[tyt-tab-content]"
)) {
ioTabBtns.observe(btn);
}
if (!related.closest("#right-tabs")) {
document.querySelector("#tab-videos").assignChildern111(null, related, null);
}
const infoExpander = elements.infoExpander;
if (infoExpander && !infoExpander.closest("#right-tabs")) {
document.querySelector("#tab-info").assignChildern111(null, infoExpander, null);
}
const commentsArea = elements.comments;
if (commentsArea && !commentsArea.closest("#right-tabs")) {
document.querySelector("#tab-comments").assignChildern111(null, commentsArea, null);
}
rightTabsProvidedPromise.resolve();
roRightTabs.disconnect();
roRightTabs.observe(rightTabs);
const ytdFlexyElm = elements.flexy;
const aoFlexy = new MutationObserver(eventMap["aoFlexyFn"]);
aoFlexy.observe(ytdFlexyElm, { attributes: true });
Promise.resolve(lockSet["fixInitialTabStateLock"]).then(eventMap["fixInitialTabStateFn"]).catch(console.warn);
ytdFlexyElm.incAttribute111("attr-7qlsy");
}
},
aoFlexyFn: () => {
Promise.resolve(lockSet["checkCommentsShouldBeHiddenLock"]).then(eventMap["checkCommentsShouldBeHidden"]).catch(console.warn);
Promise.resolve(lockSet["refreshSecondaryInnerLock"]).then(eventMap["refreshSecondaryInner"]).catch(console.warn);
Promise.resolve(lockSet["tabsStatusCorrectionLock"]).then(eventMap["tabsStatusCorrection"]).catch(console.warn);
const videoId = getCurrentVideoId();
if (videoId !== tmpLastVideoId) {
tmpLastVideoId = videoId;
Promise.resolve(lockSet["updateOnVideoIdChangedLock"]).then(eventMap["updateOnVideoIdChanged"]).catch(console.warn);
}
},
twoColumnChanged10: (lockId) => {
if (lockId !== lockGet["twoColumnChanged10Lock"])
return;
for (const continuation of document.querySelectorAll(
"#tab-videos ytd-watch-next-secondary-results-renderer ytd-continuation-item-renderer"
)) {
if (continuation.closest("[hidden]"))
continue;
const cnt = insp(continuation);
if (typeof cnt.showButton === "boolean") {
if (cnt.showButton === false)
continue;
cnt.showButton = false;
const behavior = cnt.ytRendererBehavior || cnt;
if (typeof behavior.invalidate === "function") {
behavior.invalidate(false);
}
}
}
},
tabsStatusCorrection: (lockId) => {
if (lockId !== lockGet["tabsStatusCorrectionLock"])
return;
const ytdFlexyElm = elements.flexy;
if (!ytdFlexyElm)
return;
const p = tabAStatus;
const q = calculationFn(p, 1 | 2 | 4 | 8 | 16 | 32 | 64 | 128);
let resetForPanelDisappeared = false;
if (p !== q) {
let actioned = false;
if ((p & 128) === 0 && (q & 128) === 128) {
lastPanel = "playlist";
} else if ((p & 8) === 0 && (q & 8) === 8) {
lastPanel = "chat";
} else if (((p & 4) == 4 && (q & (4 | 8)) == (0 | 0) || (p & 8) == 8 && (q & (4 | 8)) === (0 | 0)) && lastPanel === "chat") {
lastPanel = lastTab || "";
resetForPanelDisappeared = true;
} else if ((p & (4 | 8)) === 8 && (q & (4 | 8)) === 4 && lastPanel === "chat") {
lastPanel = lastTab || "";
resetForPanelDisappeared = true;
} else if ((p & 128) === 128 && (q & 128) === 0 && lastPanel === "playlist") {
lastPanel = lastTab || "";
resetForPanelDisappeared = true;
}
tabAStatus = q;
let bFixForResizedTab = false;
if ((q ^ 2) === 2 && bFixForResizedTabLater) {
bFixForResizedTab = true;
}
if ((p & 16) === 16 & (q & 16) === 0) {
Promise.resolve(lockSet["twoColumnChanged10Lock"]).then(eventMap["twoColumnChanged10"]).catch(console.warn);
}
if ((p & 2) === 2 ^ (q & 2) === 2 && (q & 2) === 2) {
bFixForResizedTab = true;
}
if ((p & 2) === 0 && (q & 2) === 2 && (p & 128) === 128 && (q & 128) === 128) {
lastPanel = lastTab || "";
ytBtnClosePlaylist();
actioned = true;
}
if ((p & (8 | 128)) === (0 | 128) && (q & (8 | 128)) === (8 | 128) && lastPanel === "chat") {
lastPanel = lastTab || "";
ytBtnClosePlaylist();
actioned = true;
}
if ((p & (2 | 128)) === (2 | 0) && (q & (2 | 128)) === (2 | 128) && lastPanel === "playlist") {
switchToTab(null);
actioned = true;
}
if ((p & (8 | 128)) === (8 | 0) && (q & (8 | 128)) === (8 | 128) && lastPanel === "playlist") {
lastPanel = lastTab || "";
ytBtnCollapseChat();
actioned = true;
}
if ((p & (1 | 16 | 128)) == (1 | 16) && (q & (1 | 16 | 128)) == (1 | 16 | 128)) {
ytBtnCancelTheater();
actioned = true;
}
if ((p & (1 | 16 | 128)) == (16 | 128) && (q & (1 | 16 | 128)) == (1 | 16 | 128)) {
lastPanel = lastTab || "";
ytBtnClosePlaylist();
actioned = true;
}
if ((q & 64) === 64) {
actioned = false;
} else if ((p & 64) == 64 && (q & 64) === 0) {
if ((q & 32) === 32) {
ytBtnCloseEngagementPanels();
}
if ((q & (2 | 8)) === (2 | 8)) {
if (lastPanel === "chat") {
switchToTab(null);
actioned = true;
} else if (lastPanel) {
ytBtnCollapseChat();
actioned = true;
}
}
} else if ((p & (1 | 2 | 8 | 16 | 32)) === (1 | 0 | 0 | 16 | 0) && (q & (1 | 2 | 8 | 16 | 32)) === (1 | 0 | 8 | 16 | 0)) {
ytBtnCancelTheater();
actioned = true;
} else if ((p & (1 | 16 | 32)) === (0 | 16 | 0) && (q & (1 | 16 | 32)) === (0 | 16 | 32) && (q & (2 | 8)) > 0) {
if (q & 2) {
switchToTab(null);
actioned = true;
}
if (q & 8) {
ytBtnCollapseChat();
actioned = true;
}
} else if ((p & (1 | 16 | 8 | 2)) === (16 | 8) && (q & (1 | 16 | 8 | 2)) === 16 && (q & 128) === 0) {
if (lastTab) {
switchToTab(lastTab);
actioned = true;
}
} else if ((p & 1) === 0 && (q & 1) === 1) {
if ((q & 32) === 32) {
ytBtnCloseEngagementPanels();
}
if ((p & 9) === 8 && (q & 9) === 9) {
ytBtnCollapseChat();
}
switchToTab(null);
actioned = true;
} else if ((p & 3) === 1 && (q & 3) === 3) {
ytBtnCancelTheater();
actioned = true;
} else if ((p & 10) === 2 && (q & 10) === 10) {
switchToTab(null);
actioned = true;
} else if ((p & (8 | 32)) === (0 | 32) && (q & (8 | 32)) === (8 | 32)) {
ytBtnCloseEngagementPanels();
actioned = true;
} else if ((p & (2 | 32)) === (0 | 32) && (q & (2 | 32)) === (2 | 32)) {
ytBtnCloseEngagementPanels();
actioned = true;
} else if ((p & (2 | 8)) === (0 | 8) && (q & (2 | 8)) === (2 | 8)) {
ytBtnCollapseChat();
actioned = true;
} else if ((p & 1) === 1 && (q & (1 | 32)) === (0 | 0)) {
if (lastPanel === "chat") {
ytBtnExpandChat();
actioned = true;
} else if (lastPanel === lastTab && lastTab) {
switchToTab(lastTab);
actioned = true;
}
}
if (!actioned && (q & 128) === 128) {
lastPanel = "playlist";
if ((q & 2) === 2) {
switchToTab(null);
actioned = true;
}
}
if ((p & 2) === 2 && (q & (2 | 128)) === (0 | 128)) {
} else if ((p & 8) === 8 && (q & (8 | 128)) === (0 | 128)) {
} else if (!actioned && (p & (1 | 16)) === 16 && (q & (1 | 16 | 8 | 2 | 32 | 64)) === (16 | 0 | 0)) {
if (lastPanel === "chat") {
ytBtnExpandChat();
actioned = true;
} else if (lastPanel === "playlist") {
ytBtnOpenPlaylist();
actioned = true;
} else if (lastTab) {
switchToTab(lastTab);
actioned = true;
} else if (resetForPanelDisappeared) {
Promise.resolve(lockSet["fixInitialTabStateLock"]).then(eventMap["fixInitialTabStateFn"]).catch(console.warn);
actioned = true;
}
}
if (bFixForResizedTab) {
bFixForResizedTabLater = false;
Promise.resolve(0).then(eventMap["fixForTabDisplay"]).catch(console.warn);
}
if ((p & 16) === 16 ^ (q & 16) === 16) {
Promise.resolve(lockSet["infoFixLock"]).then(infoFix).catch(console.warn);
Promise.resolve(lockSet["removeKeepCommentsScrollerLock"]).then(removeKeepCommentsScroller).catch(console.warn);
Promise.resolve(lockSet["layoutFixLock"]).then(layoutFix).catch(console.warn);
}
}
},
updateOnVideoIdChanged: (lockId) => {
if (lockId !== lockGet["updateOnVideoIdChangedLock"])
return;
const videoId = tmpLastVideoId;
if (!videoId)
return;
const bodyRenderer = elements.infoExpanderRendererBack;
const bodyRendererNew = elements.infoExpanderRendererFront;
if (bodyRendererNew && bodyRenderer) {
insp(bodyRendererNew).data = insp(bodyRenderer).data;
}
Promise.resolve(lockSet["infoFixLock"]).then(infoFix).catch(console.warn);
},
fixInitialTabStateFn: async (lockId) => {
if (lockGet["fixInitialTabStateLock"] !== lockId)
return;
const delayTime = fixInitialTabStateK > 0 ? 200 : 1;
await delayPn(delayTime);
if (lockGet["fixInitialTabStateLock"] !== lockId)
return;
const kTab = document.querySelector("[tyt-tab]");
const qTab = !kTab || kTab.getAttribute("tyt-tab") === "" ? checkElementExist("ytd-watch-flexy[is-two-columns_]", "[hidden]") : null;
if (checkElementExist(
"ytd-playlist-panel-renderer#playlist",
"[hidden], [collapsed]"
)) {
switchToTab(null);
} else if (checkElementExist("ytd-live-chat-frame#chat", "[hidden], [collapsed]")) {
switchToTab(null);
if (checkElementExist("ytd-watch-flexy[theater]", "[hidden]")) {
ytBtnCollapseChat();
}
} else if (qTab) {
const hasTheater = qTab.hasAttribute("theater");
if (!hasTheater) {
const btn0 = document.querySelector(".tab-btn-visible");
if (btn0) {
switchToTab(btn0);
} else {
switchToTab(null);
}
} else {
switchToTab(null);
}
} else {
}
fixInitialTabStateK++;
},
"tabs-btn-click": (evt) => {
const target = evt.target;
if (target instanceof HTMLElement_ && target.classList.contains("tab-btn") && target.hasAttribute000("tyt-tab-content")) {
evt.preventDefault();
evt.stopPropagation();
evt.stopImmediatePropagation();
const activeLink = target;
switchToTab(activeLink);
}
}
};
Promise.all([videosElementProvidedPromise, navigateFinishedPromise]).then(eventMap["onceInsertRightTabs"]).catch(console.warn);
Promise.all([navigateFinishedPromise, infoExpanderElementProvidedPromise]).then(eventMap["onceInfoExpanderElementProvidedPromised"]).catch(console.warn);
const isCustomElementsProvided = typeof customElements !== "undefined" && typeof (customElements || 0).whenDefined === "function";
const promiseForCustomYtElementsReady = isCustomElementsProvided ? Promise.resolve(0) : new Promise((callback) => {
const EVENT_KEY_ON_REGISTRY_READY = "ytI-ce-registry-created";
if (typeof customElements === "undefined") {
if (!("__CE_registry" in document)) {
Object.defineProperty(document, "__CE_registry", {
get() {
},
set(nv) {
if (typeof nv == "object") {
delete this.__CE_registry;
this.__CE_registry = nv;
this.dispatchEvent(
new CustomEvent(EVENT_KEY_ON_REGISTRY_READY)
);
}
return true;
},
enumerable: false,
configurable: true
});
}
let eventHandler = (evt) => {
document.removeEventListener(
EVENT_KEY_ON_REGISTRY_READY,
eventHandler,
false
);
const f = callback;
callback = null;
eventHandler = null;
f();
};
document.addEventListener(
EVENT_KEY_ON_REGISTRY_READY,
eventHandler,
false
);
} else {
callback();
}
});
const _retrieveCE = async (nodeName) => {
try {
isCustomElementsProvided || await promiseForCustomYtElementsReady;
await customElements.whenDefined(nodeName);
} catch (e) {
}
};
const retrieveCE = async (nodeName) => {
try {
isCustomElementsProvided || await promiseForCustomYtElementsReady;
await customElements.whenDefined(nodeName);
const dummy = document.querySelector(nodeName) || document.createElement(nodeName);
const cProto = insp(dummy).constructor.prototype;
return cProto;
} catch (e) {
}
};
const moOverallRes = {
_yt_playerProvided: () => (window || 0)._yt_player || 0 || 0
};
let promiseWaitNext = null;
const moOverall = new MutationObserver(() => {
if (promiseWaitNext) {
promiseWaitNext.resolve();
promiseWaitNext = null;
}
if (typeof moOverallRes._yt_playerProvided === "function") {
const r = moOverallRes._yt_playerProvided();
if (r) {
moOverallRes._yt_playerProvided = r;
eventMap._yt_playerProvided();
}
}
});
moOverall.observe(document, { subtree: true, childList: true });
const moEgmPanelReady = new MutationObserver((mutations) => {
for (const mutation of mutations) {
const target = mutation.target;
if (!target.hasAttribute000("tyt-egm-panel-jclmd"))
continue;
if (target.hasAttribute000("target-id") && target.hasAttribute000("visibility")) {
target.removeAttribute000("tyt-egm-panel-jclmd");
moEgmPanelReadyClearFn();
Promise.resolve(target).then(
eventMap["ytd-engagement-panel-section-list-renderer::bindTarget"]
).catch(console.warn);
}
}
});
const moEgmPanelReadyClearFn = () => {
if (document.querySelector("[tyt-egm-panel-jclmd]") === null) {
moEgmPanelReady.takeRecords();
moEgmPanelReady.disconnect();
}
};
document.addEventListener(
"yt-navigate-finish",
eventMap["yt-navigate-finish"],
false
);
document.addEventListener(
"animationstart",
(evt) => {
const f = eventMap[evt.animationName];
if (typeof f === "function")
f(evt.target);
},
capturePassive
);
mLoaded.flag |= 1;
document.documentElement.setAttribute111(
"tabview-loaded",
mLoaded.makeString()
);
promiseForCustomYtElementsReady.then(eventMap["ceHack"]).catch(console.warn);
executionFinished = 1;
} catch (e) {
}
};
const StorageUtil = {
keys: {
youtube: {
videoPlaySpeed: "yt/videoPlaySpeed",
functionState: {
commentTable: "yt/commentTable",
themeProgressBar: "yt/themeProgressBar",
screenShot: "yt/screenShot",
speedControl: "yt/speedControl",
markOrRemoveAd: "yt/markOrRemoveAd"
},
theme: "yt/theme"
}
},
getValue: function(key, defaultValue) {
return GM_getValue(key, defaultValue);
},
setValue: function(key, value) {
GM_setValue(key, value);
}
};
const Theme = {
setTheme: function(theme = "light", isReload = true) {
if (theme === "light") {
this.setLight(isReload);
} else if (theme === "dark") {
this.setDark(isReload);
} else {
this.setLight(isReload);
}
},
setDark: function(isReload) {
this.isDarkTheme(true, isReload);
},
setLight: function(isReload) {
this.isDarkTheme(false, isReload);
},
reloadYouTube: function() {
location.reload();
},
isDarkTheme: function(enabled, isReload) {
GM_cookie.list({ name: "PREF" }, (cookies) => {
const pref = cookies && cookies.length != 0 ? cookies[0] : null;
const cookie = {
url: "https://www.youtube.com",
domain: ".youtube.com",
name: "PREF",
value: pref ? pref.value : "f6=400"
};
cookie.value = cookie.value.replace(/&f6=\d+/, "").replace(/f6=\d+/, "");
const prefix = cookie.value ? "&" : "";
if (enabled) {
cookie.value += prefix + "f6=400";
} else {
cookie.value += prefix + "f6=80000";
}
GM_cookie.set(cookie, (error) => {
if (isReload)
this.reloadYouTube();
});
});
},
init: function() {
const theme = StorageUtil.getValue(StorageUtil.keys.youtube.theme, "light");
this.setTheme(theme, false);
GM_registerMenuCommand("Switch theme, Light or Dark ?", () => {
let currentTheme = StorageUtil.getValue(StorageUtil.keys.youtube.theme, "light");
if (currentTheme == "light") {
currentTheme = "dark";
} else {
currentTheme = "light";
}
StorageUtil.setValue(StorageUtil.keys.youtube.theme, currentTheme);
this.setTheme(currentTheme, true);
});
}
};
const commonUtil = {
onPageLoad: function(callback) {
if (document.readyState === "complete") {
callback();
} else {
window.addEventListener("DOMContentLoaded", callback, { once: true });
window.addEventListener("load", callback, { once: true });
}
},
addStyle: function(style) {
GM_addStyle(style);
},
openInTab: function(url, options = { "active": true, "insert": true, "setParent": true }) {
if (typeof GM_openInTab === "function") {
GM_openInTab(url, options);
} else {
GM.openInTab(url, options);
}
},
waitForElementByInterval: function(selector, target = document.body, allowEmpty = true, delay = 10, maxDelay = 10 * 1e3) {
return new Promise((resolve, reject) => {
let totalDelay = 0;
let element = target.querySelector(selector);
let result = allowEmpty ? !!element : !!element && !!element.innerHTML;
if (result) {
resolve(element);
}
const elementInterval = setInterval(() => {
if (totalDelay >= maxDelay) {
clearInterval(elementInterval);
resolve(null);
}
element = target.querySelector(selector);
result = allowEmpty ? !!element : !!element && !!element.innerHTML;
if (result) {
clearInterval(elementInterval);
resolve(element);
} else {
totalDelay += delay;
}
}, delay);
});
}
};
const DownloadYT = {
download: async function() {
const downloadUl = await this.getDownloadUrl(window.location.href.replace("music.youtube.com", "www.youtube.com"));
commonUtil.openInTab(downloadUl);
},
getDownloadUrl: function(videoUrl, audioOnly = false) {
return new Promise((resolve, reject) => {
resolve("https://www.yt1s.com/youtube-to-mp4?q=" + encodeURIComponent(videoUrl));
});
},
start: function() {
GM_registerMenuCommand("Download the currently playing video or audio.", () => {
this.download();
});
}
};
var css_248z = ".html5-play-progress,.ytp-play-progress{background:url(\"\") repeat-x!important;background:linear-gradient(180deg,red 0,red 16.5%,#f90 0,#f90 33%,#ff0 0,#ff0 50%,#3f0 0,#3f0 66%,#09f 0,#09f 83.5%,#63f 0,#63f)!important;background:-webkit-linear-gradient(top,red,red 16.5%,#f90 0,#f90 33%,#ff0 0,#ff0 50%,#3f0 0,#3f0 66%,#09f 0,#09f 83.5%,#63f 0,#63f)!important;background:-moz-linear-gradient(top,red 0,red 16.5%,#f90 16.5%,#f90 33%,#ff0 33%,#ff0 50%,#3f0 50%,#3f0 66%,#09f 66%,#09f 83.5%,#63f 83.5%,#63f 100%)!important}.html5-load-progress,.ytp-load-progress{background:url(\"\")!important}.html5-scrubber-button,.ytp-scrubber-button{background:url(\"\")!important;border:none!important;height:21px!important;margin-left:-18px!important;margin-top:0!important;transform:scale(.8);-webkit-transform:scale(.8);-moz-transform:scale(.8);-ms-transform:scale(.8);width:34px!important}.ytp-progress-bar-container:hover .ytp-load-progress,.ytp-progress-bar-container:hover .ytp-scrubber-button{image-rendering:pixelated}.html5-progress-bar-container,.ytp-progress-bar-container{height:12px!important}.html5-progress-bar,.ytp-progress-bar{margin-top:12px!important}.html5-progress-list,.video-ads .html5-progress-list.html5-ad-progress-list,.video-ads .ytp-progress-list.ytp-ad-progress-list,.ytp-progress-list{height:12px!important}.ytp-volume-slider-track{background:#0c4177!important}";
const ThemeProgressbar = {
start: function() {
GM_addStyle(css_248z);
}
};
const Screenshot = {
run: function() {
return new Promise((resolve) => {
const screenShot = StorageUtil.getValue(StorageUtil.keys.youtube.functionState.screenShot, true);
if (!screenShot) {
resolve();
return;
}
commonUtil.onPageLoad(async () => {
await this.genrate();
});
});
},
genrate: async function() {
const svg = document.createElementNS("http://www.w3.org/2000/svg", "svg");
const path = document.createElementNS("http://www.w3.org/2000/svg", "path");
svg.appendChild(path);
svg.setAttribute("viewbox", "0 0 22 18");
svg.setAttribute("width", "22px");
svg.setAttribute("height", "18px");
svg.setAttribute("fill", "#fff");
path.setAttribute("d", "M 22 4.9 Q 22 3.8 21.2 3.05 20.4 2.25 19.3 2.25 L 16.4 2.25 16 1.3 Q 15.65 0.5 14.9 0.2 14.55 0.05 14.25 0 L 7.75 0 Q 7.45 0.05 7.1 0.2 6.35 0.5 6 1.3 L 5.6 2.25 2.7 2.25 Q 1.6 2.25 0.85 3.05 0.05 3.8 0 4.9 L 0 15.3 Q 0.05 16.4 0.85 17.15 1.6 17.95 2.7 18 L 19.3 18 Q 20.4 17.95 21.2 17.15 22 16.4 22 15.3 L 22 4.9 M 11 4.9 Q 13.15 4.9 14.7 6.4 16.2 7.95 16.2 10.1 16.2 12.3 14.7 13.8 13.15 15.3 11 15.3 8.85 15.3 7.35 13.8 5.8 12.3 5.8 10.1 5.8 7.95 7.35 6.4 8.85 4.9 11 4.9 M 13.4 7.75 Q 12.4 6.75 11 6.75 9.6 6.75 8.6 7.75 7.65 8.7 7.65 10.1 7.65 11.5 8.6 12.5 9.6 13.5 11 13.5 12.4 13.5 13.4 12.5 14.35 11.5 14.35 10.1 14.35 8.7 13.4 7.75 Z");
const div1 = document.createElement("div");
div1.className = "ytp-button ScreenShot_Codehemu";
div1.setAttribute("style", `position: relative;display: inline-block;width: 48px;height: 100%;`);
const div2 = document.createElement("div");
div2.setAttribute("style", `position: absolute;width: 100%;height: 100%;	`);
const YT_ScreenShotButton_Codehemu = document.createElement("button");
YT_ScreenShotButton_Codehemu.setAttribute("style", `background-color: transparent;width: 100%;height: 100%;outline: none;flex: 1 1 0%;display: flex;-webkit-box-align: center;align-items: center;-webkit-box-pack: center;justify-content: center;border: none;padding: 0px;cursor: pointer;`);
div1.onclick = this.screenshot;
div1.appendChild(div2);
div2.appendChild(YT_ScreenShotButton_Codehemu);
YT_ScreenShotButton_Codehemu.appendChild(svg);
const YT_ScreenShort_Codehemu = await commonUtil.waitForElementByInterval(".ytp-right-controls");
const ScreenShot_Codehemu = document.querySelector(".ScreenShot_Codehemu");
if (YT_ScreenShort_Codehemu && !ScreenShot_Codehemu) {
YT_ScreenShort_Codehemu.prepend(div1);
}
},
screenshot: function() {
var SF_Codhemeu = "png";
var extension = "png";
var appendixTitle = "screenshot." + extension;
var title;
var headerEls = document.querySelectorAll(
"h1.title.ytd-video-primary-info-renderer"
);
function SetTitle() {
if (headerEls.length > 0) {
title = headerEls[0].innerText.trim();
return true;
} else {
return false;
}
}
if (SetTitle() == false) {
headerEls = document.querySelectorAll("h1.watch-title-container");
if (SetTitle() == false)
title = "";
}
var player = document.getElementsByClassName("video-stream")[0];
var time = player.currentTime;
title += " ";
let minutes = Math.floor(time / 60);
time = Math.floor(time - minutes * 60);
if (minutes > 60) {
let hours = Math.floor(minutes / 60);
minutes -= hours * 60;
title += hours + "-";
}
title += minutes + "-" + time;
title += " " + appendixTitle;
var canvas = document.createElement("canvas");
canvas.width = player.videoWidth;
canvas.height = player.videoHeight;
canvas.getContext("2d").drawImage(player, 0, 0, canvas.width, canvas.height);
var downloadLink = document.createElement("a");
downloadLink.download = title;
function DownloadBlob(blob) {
downloadLink.href = URL.createObjectURL(blob);
downloadLink.click();
}
{
canvas.toBlob(async function(blob) {
DownloadBlob(blob);
}, "image/" + SF_Codhemeu);
}
}
};
const SpeedControl = {
currentSpeed: 1,
activeAnimationId: null,
run: function() {
return new Promise((resolve) => {
const speedControl = StorageUtil.getValue(StorageUtil.keys.youtube.functionState.speedControl, true);
if (!speedControl) {
resolve();
return;
}
const storageSpeed = StorageUtil.getValue(StorageUtil.keys.youtube.videoPlaySpeed, 1);
this.currentSpeed = parseFloat(storageSpeed);
this.insertStyle();
commonUtil.onPageLoad(async () => {
await this.genrate();
this.setVideoRate(storageSpeed);
this.videoObserver();
resolve();
});
});
},
insertStyle: function() {
const speedBtnStyle = `
.SpeedControl_Extension_Btn_X{
width: 4em !important;
float: left;
text-align: center !important;
border-radius: 0.5em;
font-size:13px;
}
.SpeedControl_Extension_Btn_X:hover{
color:red;
font-weight: bold;
}
`;
const speedShowStyle = `
#youtube-extension-text-box {
position: absolute!important;
margin: auto!important;
top: 0px!important;
right: 0px!important;
bottom: 0px!important;
left: 0px!important;
border-radius: 20px!important;
font-size: 30px!important;
background-color: #000!important;
color: #f3f3f3!important;
z-index: 99999999999999999!important;
opacity: 0.8!important;
width: 80px!important;
height: 80px!important;
line-height: 80px!important;
text-align: center!important;
padding: 0px!important;
}
`;
const speedOptionsStyle = `
.SpeedControl_Extension_Speed-Options {
position: absolute!important;
background: black!important;
color: white!important;
border-radius: 5px!important;
display: none;
bottom: calc(100% + 10px)!important;
width:48px!important;
}
.SpeedControl_Extension_Speed-Options >.SpeedControl_Extension_Speed-Option-Item {
cursor: pointer!important;
height: 25px!important;
line-height: 25px!important;
font-size:12px!important;
text-align: center!important;
}
.SpeedControl_Extension_Speed-Options >.SpeedControl_Extension_Speed-Option-Item-Active,
.SpeedControl_Extension_Speed-Options >.SpeedControl_Extension_Speed-Option-Item:hover {
color: red!important;
}
`;
commonUtil.addStyle(speedBtnStyle + speedShowStyle + speedOptionsStyle);
},
genrate: async function() {
const speedControlBtn = document.createElement("div");
speedControlBtn.className = "ytp-button SpeedControl_Extension_Btn_X";
const speedText = document.createElement("span");
speedText.textContent = "" + this.currentSpeed + "×";
speedControlBtn.appendChild(speedText);
const YT_ScreenShort_Codehemu = await commonUtil.waitForElementByInterval(".ytp-right-controls");
const ScreenShot_Codehemu_Btn = document.querySelector(".SpeedControl_Extension_Btn_X");
if (YT_ScreenShort_Codehemu && !ScreenShot_Codehemu_Btn) {
YT_ScreenShort_Codehemu.prepend(speedControlBtn);
this.genrateOptions(speedControlBtn);
}
},
genrateOptions: function(speedControl) {
const speedOptions = document.createElement("div");
speedOptions.classList.add("SpeedControl_Extension_Speed-Options");
speedControl.appendChild(speedOptions);
const speeds = ["0.5", "0.75", "1.0", "1.5", "2.0", "3.0"];
speeds.forEach((speed) => {
const option = document.createElement("div");
option.className = "SpeedControl_Extension_Speed-Option-Item";
option.textContent = `${speed}x`;
option.dataset.speed = speed;
if (parseFloat(speed) === this.currentSpeed) {
option.classList.add("SpeedControl_Extension_Speed-Option-Item-Active");
}
speedOptions.appendChild(option);
});
let isHovering = false;
speedControl.addEventListener("mouseenter", () => {
isHovering = true;
speedOptions.style.display = "block";
});
speedControl.addEventListener("mouseleave", () => {
isHovering = false;
setTimeout(() => {
if (!isHovering) {
speedOptions.style.display = "none";
}
}, 150);
});
speedOptions.addEventListener("mouseenter", () => {
isHovering = true;
});
speedOptions.addEventListener("mouseleave", () => {
isHovering = false;
speedOptions.style.display = "none";
});
speedOptions.addEventListener("click", (event) => {
speedOptions.style.display = "none";
const speedValue = parseFloat(event.target.dataset.speed);
this.speedDisplayText("" + speedValue + "×");
this.setVideoRate(speedValue);
this.currentSpeed = speedValue;
this.updateVideoPlaySpeedStorage(speedValue);
speedControl.querySelector("span").textContent = "" + speedValue + "×";
speedOptions.querySelectorAll(".SpeedControl_Extension_Speed-Option-Item").forEach((option) => {
option.classList.remove("SpeedControl_Extension_Speed-Option-Item-Active");
});
event.target.classList.add("SpeedControl_Extension_Speed-Option-Item-Active");
});
},
updateVideoPlaySpeedStorage: function(speedValue) {
StorageUtil.setValue(StorageUtil.keys.youtube.videoPlaySpeed, speedValue);
},
speedDisplayText: function(speedText) {
let elementId = "youtube-extension-text-box";
let element = document.getElementById(elementId);
if (!element) {
let mediaElement = document.getElementById("movie_player");
mediaElement.insertAdjacentHTML("afterbegin", `<div id="${elementId}">${speedText}</div>`);
element = document.getElementById(elementId);
} else {
element.textContent = speedText;
}
element.style.display = "block";
element.style.opacity = 0.8;
element.style.filter = `alpha(opacity=${0.8 * 100})`;
this.startFadeoutAnimation(element);
},
startFadeoutAnimation: function(element, startOpacity = 0.9, duration = 1500) {
let opacity = startOpacity;
const startTime = performance.now();
if (this.activeAnimationId) {
cancelAnimationFrame(this.activeAnimationId);
}
const fadeStep = (timestamp) => {
const elapsed = timestamp - startTime;
const progress = Math.min(elapsed / duration, 1);
opacity = startOpacity * (1 - progress);
element.style.opacity = opacity;
element.style.filter = `alpha(opacity=${opacity * 100})`;
if (progress < 1) {
this.activeAnimationId = requestAnimationFrame(fadeStep);
} else {
element.style.display = "none";
this.activeAnimationId = null;
}
};
this.activeAnimationId = requestAnimationFrame(fadeStep);
},
setVideoRate: function(speed) {
const videoElement = document.querySelector("video");
if (!videoElement)
return;
videoElement.playbackRate = speed;
},
videoObserver: function() {
const checkVideoInterval = setInterval(() => {
const videoElement = document.querySelector("video");
if (videoElement) {
clearInterval(checkVideoInterval);
const observer = new MutationObserver((mutationsList) => {
for (const mutation of mutationsList) {
if (mutation.type === "attributes" && mutation.attributeName === "src") {
videoElement.playbackRate = this.currentSpeed;
}
}
});
observer.observe(videoElement, {
attributes: true
});
}
}, 1500);
}
};
const MarkOrRemoveAd = {
generateRemoveAdElementId: "removeADHTMLElement_" + Math.ceil(Math.random() * 1e8),
markADHTMLElement: function() {
if (document.querySelector(this.generateRemoveAdElementId)) {
return;
}
let cssMarkSelectorArr = [
`#masthead-ad`,
`ytd-rich-item-renderer.style-scope.ytd-rich-grid-row #content:has(.ytd-display-ad-renderer)`,
`.video-ads.ytp-ad-module`,
`tp-yt-paper-dialog:has(yt-mealbar-promo-renderer)`,
`ytd-engagement-panel-section-list-renderer[target-id="engagement-panel-ads"]`,
`#related #player-ads`,
`#related ytd-ad-slot-renderer`,
`ytd-ad-slot-renderer`,
`yt-mealbar-promo-renderer`,
`ytd-popup-container:has(a[href="/premium"])`,
`ad-slot-renderer`,
`ytm-companion-ad-renderer`
];
cssMarkSelectorArr.forEach((selector, index) => {
cssMarkSelectorArr[index] = `${selector} *{text-decoration:line-through!important;text-decoration-thickness:2px!important;}`;
});
const cssText = cssMarkSelectorArr.join(" ");
const style = document.createElement(`style`);
style.id = this.generateRemoveAdElementId;
(document.head || document.body).appendChild(style);
style.appendChild(document.createTextNode(cssText));
},
run: function() {
commonUtil.onPageLoad(() => {
this.markADHTMLElement();
});
}
};
/*!
* credit to Benjamin Philipp
* MIT
* original source: https://greasyfork.org/en/scripts/433051-trusted-types-helper
*/
const overwrite_default = false;
GM_info.script.name;
const passThroughFunc = function(string, sink) {
return string;
};
var TTPName = "passthrough";
var TTP_default, TTP = { createHTML: passThroughFunc, createScript: passThroughFunc, createScriptURL: passThroughFunc };
var needsTrustedHTML = false;
!window.TTP && (() => {
try {
if (typeof window.isSecureContext !== "undefined" && window.isSecureContext) {
if (window.trustedTypes && window.trustedTypes.createPolicy) {
needsTrustedHTML = true;
if (trustedTypes.defaultPolicy) {
if (overwrite_default) ; else {
TTP = window.trustedTypes.createPolicy(TTPName, TTP);
}
TTP_default = trustedTypes.defaultPolicy;
} else {
TTP_default = TTP = window.trustedTypes.createPolicy(
"default",
TTP
);
}
}
}
} catch (e) {
} finally {
window.TTP = TTP;
}
})();
const createHTML = (s) => {
if (typeof TTP !== "undefined" && typeof TTP.createHTML === "function")
return TTP.createHTML(s);
return s;
};
(async () => {
const communicationKey = `ck-${Date.now()}-${Math.floor(Math.random() * 314159265359 + 314159265359).toString(36)}`;
const Promise = (async () => {
})().constructor;
if (!document.documentElement) {
await Promise.resolve(0);
while (!document.documentElement) {
await new Promise((resolve) => nextBrowserTick(resolve)).then().catch(console.warn);
}
}
const sourceURL = "debug://tabview-youtube/tabview.execution.js";
const textContent = `(${executionScript})("${communicationKey}");${"\n\n"}//# sourceURL=${sourceURL}${"\n"}`;
let button = document.createElement("button");
button.setAttribute("onclick", createHTML(textContent));
button.click();
button = null;
let style = document.createElement("style");
const sourceURLMainCSS = "debug://tabview-youtube/tabview.main.css";
style.textContent = `${styles["main"].trim()}${"\n\n"}/*# sourceURL=${sourceURLMainCSS} */${"\n"}`;
document.documentElement.appendChild(style);
})();
{
DownloadYT.start();
}
{
ThemeProgressbar.start();
}
{
Theme.init();
}
{
MarkOrRemoveAd.run();
}
(async () => {
{
Screenshot.run();
}
{
SpeedControl.run();
}
})();
}());