您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Make the Youtube comments section visible from the sidebar
- // ==UserScript==
- // @name move-youtube-comments-to-sidebar
- // @version 1.0.1
- // @license MIT
- // @name:ja YouTubeのコメント欄をサイドバーで見れるようにする
- // @author yakisova41
- // @description Make the Youtube comments section visible from the sidebar
- // @description:ja YouTubeのコメント欄をサイドバーから見れるようにします。
- // @match https://www.youtube.com/*
- // @namespace https://yakisova.com
- // @icon 
- // ==/UserScript==
- (() => {
- var __create = Object.create;
- var __defProp = Object.defineProperty;
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
- var __getOwnPropNames = Object.getOwnPropertyNames;
- var __getProtoOf = Object.getPrototypeOf;
- var __hasOwnProp = Object.prototype.hasOwnProperty;
- var __esm = (fn, res) => function __init() {
- return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
- };
- var __commonJS = (cb, mod) => function __require() {
- return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
- };
- var __copyProps = (to, from, except, desc) => {
- if (from && typeof from === "object" || typeof from === "function") {
- for (let key of __getOwnPropNames(from))
- if (!__hasOwnProp.call(to, key) && key !== except)
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
- }
- return to;
- };
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
- // If the importer is in node compatibility mode or this is not an ESM
- // file that has been converted to a CommonJS file using a Babel-
- // compatible transform (i.e. "__esModule" has not been set), then set
- // "default" to the CommonJS "module.exports" for node compatibility.
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
- mod
- ));
- // src/findElement.ts
- var findElement;
- var init_findElement = __esm({
- "src/findElement.ts"() {
- findElement = (selector) => {
- return new Promise((resolve) => {
- const interval = setInterval(() => {
- const elem = document.querySelector(selector);
- if (elem !== null) {
- clearInterval(interval);
- resolve(elem);
- }
- });
- });
- };
- }
- });
- // src/css/style.css
- var require_style = __commonJS({
- "src/css/style.css"(exports, module) {
- (function() {
- if (!document.getElementById("7e1065fb51bb77ce35a77cffc916cbd9c74a211ded1e7f6c59e5d2b931e3a9eb")) {
- var e = document.createElement("style");
- e.id = "7e1065fb51bb77ce35a77cffc916cbd9c74a211ded1e7f6c59e5d2b931e3a9eb";
- e.textContent = `.mycsButton_cbfc566d866c2a43bc5bcf5094735b68_1{background:var(--yt-spec-badge-chip-background);border:none;color:var(--yt-spec-text-primary);font-size:14px;line-height:36px;height:36px;padding:0 16px;margin-left:8px;border-radius:18px;cursor:pointer;font-family:"Roboto; Arial; sans-serif;";position:relative;display:flex;justify-content:center;align-items:center}.mycsButton_cbfc566d866c2a43bc5bcf5094735b68_1>svg{fill:var(--yt-spec-text-primary)}.mycsButtonDown_cbfc566d866c2a43bc5bcf5094735b68_1{border-radius:18px;position:absolute;width:100%;height:100%;top:0;left:0}.mycsButton_cbfc566d866c2a43bc5bcf5094735b68_1:hover{background:var(--yt-spec-mono-tonal-hover)}.mycsButtonDown_cbfc566d866c2a43bc5bcf5094735b68_1:active{background:var(--yt-spec-touch-response);opacity:.1}.mycsCommentArea_cbfc566d866c2a43bc5bcf5094735b68_1{width:100%}.mycsCommentAreaSecondaryInner_cbfc566d866c2a43bc5bcf5094735b68_1{height:var(--ytd-watch-flexy-chat-max-height);margin-bottom:20px}.mycsCommentAreaBelow_cbfc566d866c2a43bc5bcf5094735b68_1{height:calc(100vh - 56.25vw - var(--ytd-margin-6x) - 56px);margin:20px 0}.mycsCommentInner_cbfc566d866c2a43bc5bcf5094735b68_1{width:100%;height:100%;border-radius:12px;border:solid 1px var(--ytd-searchbox-legacy-button-border-color)}.mycsComments_cbfc566d866c2a43bc5bcf5094735b68_1{overflow-y:scroll;overscroll-behavior:contain;padding:0 20px;height:100%}.mycsComments_cbfc566d866c2a43bc5bcf5094735b68_1::-webkit-scrollbar-thumb{height:56px;border-radius:8px;border:4px solid transparent;background-clip:content-box;background-color:var(--yt-spec-icon-disabled)}.mycsComments_cbfc566d866c2a43bc5bcf5094735b68_1::-webkit-scrollbar{background:transparent;width:16px}.mycsHidden_cbfc566d866c2a43bc5bcf5094735b68_1{display:none}`;
- document.head.appendChild(e);
- }
- })();
- module.exports = JSON.parse('{"mycsButton":"mycsButton_cbfc566d866c2a43bc5bcf5094735b68_1","mycsButtonDown":"mycsButtonDown_cbfc566d866c2a43bc5bcf5094735b68_1","mycsCommentArea":"mycsCommentArea_cbfc566d866c2a43bc5bcf5094735b68_1","mycsCommentAreaSecondaryInner":"mycsCommentAreaSecondaryInner_cbfc566d866c2a43bc5bcf5094735b68_1","mycsCommentAreaBelow":"mycsCommentAreaBelow_cbfc566d866c2a43bc5bcf5094735b68_1","mycsCommentInner":"mycsCommentInner_cbfc566d866c2a43bc5bcf5094735b68_1","mycsComments":"mycsComments_cbfc566d866c2a43bc5bcf5094735b68_1","mycsHidden":"mycsHidden_cbfc566d866c2a43bc5bcf5094735b68_1"}');
- }
- });
- // src/addButton.ts
- var import_style, addButton_default;
- var init_addButton = __esm({
- "src/addButton.ts"() {
- init_findElement();
- import_style = __toESM(require_style());
- addButton_default = async (eventElement) => {
- const button = document.createElement("button");
- button.className = import_style.default.mycsButton;
- button.innerHTML = button.innerHTML + `<svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24" viewBox="0 0 24 24" width="24"><path d="M8,7h8v2H8V7z M8,13h5v-2H8V13z M5,3v13h10h0.41l0.29,0.29L19,19.59V3H5 M4,2h16v20l-5-5H4V2L4,2z"></path></svg>`;
- const buttonDown = document.createElement("div");
- button.appendChild(buttonDown);
- buttonDown.className = import_style.default.mycsButtonDown;
- const buttonsParent = await findElement(
- "ytd-menu-renderer.ytd-watch-metadata"
- );
- buttonsParent.appendChild(button);
- button.onclick = (e) => {
- eventElement.dispatchEvent(
- new CustomEvent("toggleClick", {
- detail: e
- })
- );
- };
- };
- }
- });
- // src/createComments.ts
- async function createComments() {
- const root = document.createElement("div");
- root.classList.add(import_style2.default.mycsCommentArea);
- root.innerHTML = `<div class=${import_style2.default.mycsCommentInner}><div class=${import_style2.default.mycsComments}></div></div>`;
- const commentsOuter = root.querySelector(`.${import_style2.default.mycsComments}`);
- const comments = await findElement("ytd-comments#comments");
- return {
- root,
- commentsOuter,
- comments
- };
- }
- async function smallMode(root) {
- const panels = await findElement("#primary-inner > #below > #panels");
- panels.before(root);
- root.classList.add(import_style2.default.mycsCommentAreaBelow);
- root.classList.remove(import_style2.default.mycsCommentAreaSecondaryInner);
- }
- async function bigMode(root) {
- const panels = await findElement("#secondary-inner > #panels");
- panels.before(root);
- root.classList.add(import_style2.default.mycsCommentAreaSecondaryInner);
- root.classList.remove(import_style2.default.mycsCommentAreaBelow);
- }
- var import_style2, createComments_default;
- var init_createComments = __esm({
- "src/createComments.ts"() {
- import_style2 = __toESM(require_style());
- init_findElement();
- createComments_default = async (eventElement) => {
- const { root, comments, commentsOuter } = await createComments();
- if (window.innerWidth > 1015) {
- bigMode(root);
- } else {
- smallMode(root);
- }
- let innerWidthTmp = 0;
- window.addEventListener("resize", () => {
- setTimeout(async () => {
- if (innerWidthTmp > 1015 && window.innerWidth < 1015) {
- await smallMode(root);
- const related = commentsOuter.querySelector("#related");
- findElement("#primary-inner > #below").then(
- (e) => e.appendChild(related)
- );
- } else if (innerWidthTmp < 1015 && window.innerWidth > 1015) {
- bigMode(root);
- }
- innerWidthTmp = window.innerWidth;
- }, 1);
- });
- eventElement.addEventListener(
- "toggleComments",
- async (e) => {
- if (e.detail) {
- root.classList.add(import_style2.default.mycsHidden);
- const commentParent = await findElement(
- "#primary-inner > #below"
- );
- commentParent.appendChild(comments);
- } else {
- root.classList.remove(import_style2.default.mycsHidden);
- commentsOuter.appendChild(comments);
- }
- }
- );
- };
- }
- });
- // src/main.ts
- function pageChangeListener(eventelement) {
- let beforeHref = "";
- const observer = new MutationObserver(() => {
- const href = location.href;
- if (href !== beforeHref) {
- eventelement.dispatchEvent(
- new CustomEvent("pageChange", {
- detail: {
- beforeHref,
- newHref: href
- }
- })
- );
- }
- beforeHref = href;
- });
- observer.observe(document.querySelector("body"), {
- childList: true,
- subtree: true
- });
- }
- function main() {
- const mycs = document.createElement("div");
- let isButtonCreated = false;
- let isCommentsCreated = false;
- let commentsHide = true;
- pageChangeListener(mycs);
- mycs.addEventListener(
- "pageChange",
- async (e) => {
- const { newHref } = e.detail;
- const pageName = newHref.split("/")[3].split("?")[0];
- if (pageName === "watch") {
- console.log(isButtonCreated);
- if (!isButtonCreated) {
- isButtonCreated = true;
- await addButton_default(mycs);
- }
- if (!isCommentsCreated) {
- isCommentsCreated = true;
- await createComments_default(mycs);
- }
- commentsHide = true;
- mycs.dispatchEvent(
- new CustomEvent("toggleComments", {
- detail: commentsHide
- })
- );
- }
- }
- );
- mycs.addEventListener("toggleClick", () => {
- if (commentsHide) {
- commentsHide = false;
- } else {
- commentsHide = true;
- }
- mycs.dispatchEvent(
- new CustomEvent("toggleComments", {
- detail: commentsHide
- })
- );
- });
- }
- var init_main = __esm({
- "src/main.ts"() {
- init_addButton();
- init_createComments();
- }
- });
- // src/index.ts
- var require_src = __commonJS({
- "src/index.ts"() {
- init_main();
- main();
- }
- });
- require_src();
- })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址