X/Twitter 乾淨化 & 加寬版面顯示

隱藏 X 多餘選單項目,左側(書籤、工作機會、社群、Premium、已認證組織、營利、廣告)、右側(訂閱 Premium、頁尾欄目)、右下(浮動訊息欄、Grok),加大、自定義推文時間軸的寬度,自定義腳本加載速度 (支援繁中、簡中、英文、日文)

目前為 2025-05-23 提交的版本,檢視 最新版本

// ==UserScript==
// @name         X/Twitter Clean-up & Wide Layout Display
// @name:zh-TW   X/Twitter 乾淨化 & 加寬版面顯示
// @name:zh-CN   X/Twitter 干净化 & 加宽版面显示
// @name:JA      X/Twitter クリーンアップ & ワイドレイアウト表示
// @namespace    https://www.tampermonkey.net/
// @version      3.5
// @description  Hide unnecessary X menu items on the left (Bookmarks, Jobs, Communities, Premium, Verified Organizations, Monetization, Ads) and right (Subscribe to Premium, Footer), Bottom right (floating message bar, Grok), Enlarge and customize the width of the tweet timeline, Custom Script Loading Speed (supports Traditional Chinese, Simplified Chinese, English, Japanese).
// @description:zh-TW  隱藏 X 多餘選單項目,左側(書籤、工作機會、社群、Premium、已認證組織、營利、廣告)、右側(訂閱 Premium、頁尾欄目)、右下(浮動訊息欄、Grok),加大、自定義推文時間軸的寬度,自定義腳本加載速度 (支援繁中、簡中、英文、日文)
// @description:zh-CN  隐藏 X 多余选单项目,左侧(书签、工作机会、社群、Premium、已认证组织、营利、广告)、右侧(订阅 Premium、页尾栏目)、右下(浮动讯息栏、Grok),加大、自定义推文时间轴的宽度,自定义脚本加载速度 (支援繁中、简中、英文、日文)
// @description:JA  Xの不要なメニュー項目を左側(ブックマーク、求人、コミュニティ、Premium、認証済み組織、収益化、広告)および右側(Premiumの購読、フッター) 右下(フローティングメッセージバー、Grok)で非表示にし、 ツイートのタイムラインの幅を拡大し、カスタマイズする、カスタムスクリプトの読み込み速度(繁体字中国語、簡体字中国語、英語、日本語に対応)。
// @author       ChatGPT
// @match        https://x.com/*
// @match        https://twitter.com/*
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_registerMenuCommand
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

  // ===【0】排除特定頁面(訊息與設定頁)===
  const excludedPaths = ['/messages', '/settings'];
  if (excludedPaths.some(path => location.pathname.startsWith(path))) {
    return;
  }

  // ===【1】預設參數設定 ===
  const defaultWidth = 1200;      // 推文時間軸預設寬度
  const defaultDebounce = 0;      // 防抖延遲預設為 0(即關閉)

  // ===【2】讀取使用者已儲存的設定 ===
  let timelineWidth = GM_getValue('timelineWidth', defaultWidth);
  let debounceDelay = GM_getValue('debounceDelay', defaultDebounce);

  // ===【3】註冊選單:時間軸寬度設定 ===
  GM_registerMenuCommand(`設定:時間軸推文寬度,目前為:${timelineWidth}px`, () => {
    const input = prompt('請輸入時間軸推文寬度(600 ~ 3000 px):', timelineWidth);
    const val = parseInt(input);
    if (!isNaN(val) && val >= 600 && val <= 3000) {
      GM_setValue('timelineWidth', val);
      location.reload();
    } else {
      alert('請輸入合理的數值(600 ~ 3000)');
    }
  });

  // ===【4】註冊選單:防抖延遲時間設定 ===
  GM_registerMenuCommand(`設定:防抖延遲時間(毫秒),目前為:${debounceDelay}ms`, () => {
    const input = prompt('請輸入防抖延遲時間(0 表示關閉,1~300 表示啟用防抖):', debounceDelay);
    const val = parseInt(input);
    if (!isNaN(val) && val >= 0 && val <= 300) {
      GM_setValue('debounceDelay', val);
      location.reload();
    } else {
      alert('請輸入合理的數值(0 ~ 300)');
    }
  });

  // ===【5】防抖函式封裝 ===
  function debounce(func, delay) {
    let timer = null;
    return function (...args) {
      clearTimeout(timer);
      timer = setTimeout(() => func.apply(this, args), delay);
    };
  }

  // ===【6】主處理函式 ===
  function cleanUpAndResize() {
    try {
      // -- 隱藏左側多語系選單項目 --
      const labels = [
        '書籤', 'Bookmarks', 'ブックマーク', '书签',
        '工作機會', 'Careers', '求人', '工作机会',
        '社群', 'Communities', 'コミュニティ', '社区',
        'Premium', 'プレミアム',
        '已認證組織', 'Verified Orgs', '認証済み組織', '认证组织',
        '營利', 'Monetization', '収益化', '营利',
        '廣告', 'Ads', '広告', '广告',
      ];
      document.querySelectorAll('nav[role="navigation"] div[dir="ltr"]').forEach(item => {
        const label = item.innerText?.trim();
        if (labels.includes(label)) {
          const top = item.closest('a, div[role="link"]');
          if (top) top.style.display = 'none';
        }
      });

      // -- 隱藏右側 Premium 推銷卡片 --
      const premiumCard = document.querySelector('.css-175oi2r[data-testid="super-upsell-UpsellCardRenderProperties"]');
      if (premiumCard) premiumCard.style.display = 'none';

      // -- 隱藏頁尾區塊(多語系 aria-label) --
      const footerLabels = ['頁尾', 'Footer', '页脚', 'フッター'];
      document.querySelectorAll('nav[role="navigation"]').forEach(nav => {
        const label = nav.getAttribute('aria-label')?.trim();
        if (label && footerLabels.includes(label)) {
          nav.style.display = 'none';
        }
      });

      // -- 隱藏右下角浮動訊息欄 --
      const messagePanels = document.querySelectorAll('div.r-173mn98.r-1rtiivn.r-hvns9x.r-1jte41z.r-5wli1b');
      messagePanels.forEach(el => {
        el.style.display = 'none';
      });

      // -- 隱藏 Grok 圖示浮動層(右下角) --
      const hideGrok = () => {
        const grokPanel = document.querySelector('div.r-1jte41z.r-bnwqim.r-y42jk5');
        if (grokPanel) {
          grokPanel.style.display = 'none';
        }
      };

      // 預先執行一次 Grok 隱藏
      hideGrok();

      // -- 加寬主內容區塊(時間軸整體) --
      const main = document.querySelector('main.css-175oi2r.r-16y2uox.r-1wbh5a2.r-1habvwh');
      if (main) {
        Object.assign(main.style, {
          width: '100%',
          maxWidth: 'none',
          marginLeft: 'auto',
          marginRight: 'auto',
        });
      }

      // -- 加寬推文容器(不同層級容器) --
      const containers = document.querySelectorAll([
        'div.r-1oszu61.r-1niwhzg.r-18u37iz.r-16y2uox.r-2llsf.r-13qz1uu.r-1wtj0ep',
        'div.r-kemksi.r-1kqtdi0.r-1ua6aaf.r-th6na.r-1phboty.r-16y2uox.r-184en5c.r-1abdc3e.r-1lg4w6u.r-f8sm7e.r-13qz1uu.r-1ye8kvj',
        'div.r-f8sm7e.r-13qz1uu.r-1ye8kvj'
      ].join(', '));
      containers.forEach(el => {
        Object.assign(el.style, {
          width: `${timelineWidth}px`,
          maxWidth: 'none',
          marginLeft: 'auto',
          marginRight: 'auto',
        });
      });

      // -- 推文操作列寬度繼承外層,避免寬度錯位 --
      const actionBars = document.querySelectorAll('div.r-1kbdv8c.r-18u37iz.r-1wtj0ep.r-1ye8kvj.r-1s2bzr4');
      actionBars.forEach(el => {
        Object.assign(el.style, {
          width: '100%',
          maxWidth: 'none',
        });
      });

    } catch (e) {
      console.error('腳本錯誤:', e);
    }
  }

  // ===【7】啟用 MutationObserver 搭配防抖監控畫面變更 ===
  const handler = debounceDelay >= 1 && debounceDelay <= 300
    ? debounce(cleanUpAndResize, debounceDelay)
    : cleanUpAndResize;

  const observer = new MutationObserver(handler);
  observer.observe(document.body, { childList: true, subtree: true });
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址