GreasyFork 黑暗模式 + 跳轉按鈕

GreasyFork黑暗模式切換,並添加GreasyFork/SleazyFork/Tampermonkey跳轉按鈕

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name          GreasyFork 黑暗模式 + 跳轉按鈕
// @name:zh-TW    GreasyFork 黑暗模式 + 跳轉按鈕
// @name:zh-CN    GreasyFork 暗黑模式 + 跳转按钮
// @name:en       GreasyFork Dark Mode + Jump Button

// @description       GreasyFork黑暗模式切換,並添加GreasyFork/SleazyFork/Tampermonkey跳轉按鈕
// @description:zh-TW GreasyFork黑暗模式切換,並添加GreasyFork/SleazyFork/Tampermonkey跳轉按鈕
// @description:zh-CN GreasyFork暗黑模式切换,并添加GreasyFork/SleazyFork/Tampermonkey跳转按钮
// @description:en    GreasyFork Dark Mode toggle with jump button between GreasyFork/SleazyFork/Tampermonkey

// @namespace     https://greasyfork.org/zh-CN/users/1338551
// @version       3.0
// @author        wei9133 + AI Combined
// @icon         

// @grant         GM_addStyle
// @grant         GM_getValue
// @grant         GM_setValue

// @match         https://greasyfork.org/*
// @match         https://sleazyfork.org/*
// @match         https://www.tampermonkey.net/*

// @license       MIT
// @compatible    chrome
// @compatible    firefox
// @compatible    opera
// @compatible    edge
// @compatible    safari

// @homepage      https://greasyfork.org/zh-CN/scripts/555665
// @homepageURL   https://greasyfork.org/zh-CN/scripts/555665
// @supportURL    https://greasyfork.org/zh-CN/scripts/555665/feedback
// ==/UserScript==

(function() {
    'use strict';

    // ========== 檢測當前網站 ==========
    const currentUrl = window.location.origin;
    const isSleazy = currentUrl.indexOf("sleazyfork") !== -1;
    const isTampermonkey = currentUrl.indexOf("tampermonkey") !== -1;
    const isGreasy = !isSleazy && !isTampermonkey;

    // ========== 黑暗模式狀態管理 ==========
    let darkModeEnabled = GM_getValue('darkMode', true);

    // ========== 黑暗模式樣式 ==========
    let bodyStyles = document.createElement('style');
    bodyStyles.id = 'darkModeStyles';

    function applyDarkMode() {
        bodyStyles.innerHTML = `
            body{
                background-color: #121517;
                color: #fff;
                background-image: url("https://wallpapercrafter.com/desktop1/612985-binary-code-binary-code-dark-technology-art-graphics.jpg");
                background-size: 100%;
            }
            p{
              background-color: rgba(0,0,0,.7);
            }
            a{
              color: #f40072;
            }
            a:hover{
              text-shadow: 1px .5px 3px #b531ff;
            }
            a:visited {
              color: #dd0b77;
            }
            .list-option-group ul {
              background-color: #000;
            }
            .list-option-group .list-current{
              border-left: 7px solid #7d1372;
              box-shadow: inset 0 1px #9d2b561a,inset 0 -1px #1b0e221a;
              margin: 0 0 0 -4px;
              padding: .4em 1em .4em calc(1em - 3px);
              background: linear-gradient(#550024,#140731);
            }
            .list-option-group a:hover,
            .list-option-group a:focus {
              background:linear-gradient(#1a142b,#680158);
              text-decoration:none;
              box-shadow:inset 0 -1px #ddd,inset 0 1px #eee;
              color: #dcdcdc;
            }
            a.discussion-title {
              color: #f3c9ff;
            }
            a.discussion-title:hover {
              color: #efb6ff;
            }
            .rating-icon{
              background-color: #000;
            }
            .user-content {
              background: linear-gradient(to right,#263351,#050c13ad 1em);
              border-left: 2px solid #636dfb;
            }
            textarea{
              background-color: #0c0e15;
              color: #dcdcdc;
              border: solid 2px #305473;
            }
            .linenums li{
              background-color: #dcdcdc;
            }
            .linenums li span{
              background-color: #dcdcdc;
            }
        `;
    }

    function removeDarkMode() {
        bodyStyles.innerHTML = '';
    }

    // 初始化樣式
    if (darkModeEnabled) {
        applyDarkMode();
    }
    document.head.appendChild(bodyStyles);

    // 元素樣式替換映射
    const estilosParaSubstituir = {
        'main-header': 'background-image: linear-gradient(rgb(91, 0, 76), rgb(9, 6, 6)); background-color: #111010;',
        'text-content': 'background-color: #0c0e0f; color: #fff; border: 1px solid #59162C; box-shadow: 0 0 5px #1557d5;',
        'script-list': 'background-color: #07060b; border: 1px solid #59162C; box-shadow: 0 0 5px #1557d5;',
        'script-info': 'background-color: #07060b; border: 1px solid #59162C; box-shadow: 0 0 5px #1557d5;',
        'script-list-sort': '',
    };

    // 替換樣式函數
    function substituirEstilos() {
        if (!darkModeEnabled) return;

        for (const seletor in estilosParaSubstituir) {
            const elementos = document.querySelectorAll(`.${seletor}, #${seletor}`);
            elementos.forEach(elemento => {
                elemento.style.cssText += estilosParaSubstituir[seletor];
            });
        }
    }

    substituirEstilos();

    // ========== 根據網站決定按鈕顏色 ==========
    let jumpButtonColor = '#FF0000';
    let jumpButtonText = '跳轉網址';

    if (isSleazy) {
        jumpButtonColor = '#FF6B35';
        jumpButtonText = '→ G站';
    } else if (isGreasy) {
        jumpButtonColor = '#990000';
        jumpButtonText = '→ S站';
    } else if (isTampermonkey) {
        jumpButtonColor = '#00485B';
        jumpButtonText = '→ S站';
    }

    // ========== 等待頁面載入完成 ==========
    function init() {
        // ========== 創建按鈕容器(日字型佈局)==========
        const buttonContainer = document.createElement('div');
        buttonContainer.id = 'buttonContainer';
        buttonContainer.style.cssText = `
            right: 10px;
            bottom: 100px;
            width: 60px;
            height: 100px;
            z-index: 9999;
            position: fixed;
            display: flex;
            flex-direction: column;
            gap: 5px;
        `;

        // 模式切換按鈕(上半部)
        const modeToggle = document.createElement('div');
        modeToggle.id = 'modeToggle';
        modeToggle.innerHTML = '🌓';
        modeToggle.title = '切換模式';
        modeToggle.style.cssText = `
            width: 100%;
            height: 45px;
            border-radius: 10px;
            background: linear-gradient(to bottom, #FFD700 50%, #1a1a1a 50%);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            box-shadow: 0 2px 8px rgba(0,0,0,0.3);
            transition: transform 0.2s;
        `;

        // 跳轉按鈕(下半部)
        const tiaozhuan = document.createElement('div');
        tiaozhuan.id = 'tiaozhuan';
        tiaozhuan.innerHTML = jumpButtonText;
        tiaozhuan.title = '跳轉網站';
        tiaozhuan.style.cssText = `
            width: 100%;
            height: 45px;
            font-size: 12px;
            border-radius: 10px;
            background: ${jumpButtonColor};
            color: #ffffff;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            box-shadow: 0 2px 8px rgba(0,0,0,0.3);
            transition: transform 0.2s;
        `;

        buttonContainer.appendChild(modeToggle);
        buttonContainer.appendChild(tiaozhuan);
        document.body.appendChild(buttonContainer);

        // 按鈕懸停效果
        [modeToggle, tiaozhuan].forEach(btn => {
            btn.addEventListener('mouseenter', function() {
                this.style.transform = 'scale(1.05)';
            });
            btn.addEventListener('mouseleave', function() {
                this.style.transform = 'scale(1)';
            });
        });

        // ========== 模式切換功能 ==========
        modeToggle.addEventListener('click', function() {
            darkModeEnabled = !darkModeEnabled;
            GM_setValue('darkMode', darkModeEnabled);

            if (darkModeEnabled) {
                applyDarkMode();
                substituirEstilos();
            } else {
                removeDarkMode();
                // 移除額外樣式
                for (const seletor in estilosParaSubstituir) {
                    const elementos = document.querySelectorAll(`.${seletor}, #${seletor}`);
                    elementos.forEach(elemento => {
                        elemento.style.cssText = '';
                    });
                }
            }
        });

        // ========== 跳轉按鈕功能 ==========
        tiaozhuan.addEventListener('click', function() {
            let targetUrl = window.location.origin;

            if (isSleazy) {
                // SleazyFork → GreasyFork
                targetUrl = targetUrl.replace("sleazyfork", "greasyfork") + "/zh-CN/scripts";
            } else if (isTampermonkey) {
                // Tampermonkey → SleazyFork
                targetUrl = targetUrl.replace("www", "sleazyfork");
                targetUrl = targetUrl.replace("tampermonkey.net", "org/zh-CN/scripts");
            } else {
                // GreasyFork → SleazyFork
                targetUrl = targetUrl.replace("greasyfork", "sleazyfork") + "/zh-CN/scripts";
            }

            window.location.assign(targetUrl);
        });
    }

    // 等待 DOM 載入完成
    if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', init);
    } else {
        init();
    }

})();