Noise's 2016 Website UI Tweaks

Multiple UI Tweaks to make the website look more accurate to how it was back in 2016!

当前为 2025-03-07 提交的版本,查看 最新版本

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Noise's 2016 Website UI Tweaks
// @namespace    http://tampermonkey.net/
// @version      2.1
// @description  Multiple UI Tweaks to make the website look more accurate to how it was back in 2016!
// @author       The Noise!
// @match        https://*.roblox.com/*
// @icon        
// @license MIT

// ==/UserScript==

(function () {
    'use strict';

    const modifyUI = () => {
        // Remove "Money" navigation element
        const moneyNav = document.querySelector('a#nav-money');
        if (moneyNav) {
            moneyNav.remove();
            console.log('Removed "Money" navigation element.');
        }

        // Remove "Premium" navigation element
        const premiumNav = document.querySelector('a#nav-premium');
        if (premiumNav) {
            premiumNav.remove();
            console.log('Removed "Premium" navigation element.');
        }

        // Replace "Communities" with "Groups"
        document.querySelectorAll('span.font-header-2.dynamic-ellipsis-item[title="Communities"]').forEach(element => {
            if (element.textContent.trim() === "Communities") {
                element.textContent = "Groups";
                console.log('Replaced "Communities" with "Groups".');
            }
        });

        // Replace "Communities" in visible text nodes
        document.querySelectorAll('*:not(script):not(style)').forEach(node => {
            if (node.childNodes.length) {
                node.childNodes.forEach(child => {
                    if (child.nodeType === Node.TEXT_NODE && child.nodeValue.includes("Communities")) {
                        child.nodeValue = child.nodeValue.replace(/Communities/g, "Groups");
                    }
                });
            }
        });

        // Replace "Join Community" with "Join Group" on group buttons
        const joinButtons = document.querySelectorAll('button#group-join-button');
        joinButtons.forEach(button => {
            if (button.textContent.trim() === "Join Community") {
                button.textContent = "Join Group";
                console.log('Replaced "Join Community" with "Join Group" on button.');
            }
        });

        // Replace "Leave Community" with "Leave Group" on group buttons
        const leaveButtons = document.querySelectorAll('button.ng-binding');
        leaveButtons.forEach(button => {
            if (button.textContent.trim() === "Leave Community") {
                button.textContent = "Leave Group";
                console.log('Replaced "Leave Community" with "Leave Group" on button.');
            }
        });

        // Replace "Configure Community" with "Configure Group" in anchor elements
        const configureLinks = document.querySelectorAll('a.ng-binding');
        configureLinks.forEach(link => {
            if (link.textContent.trim() === "Configure Community") {
                link.textContent = "Configure Group";
                console.log('Replaced "Configure Community" with "Configure Group".');
            }
        });
    };

    // Run immediately to apply changes
    modifyUI();

    // Observe the DOM for dynamic changes
    const observer = new MutationObserver(() => {
        modifyUI();
    });

    observer.observe(document.body, { childList: true, subtree: true });
})();