Fuck-OpenAI-Sharing-Tab

Obliterates ChatGPT's sneaky share button, blocks all sharing, and flexes with a status badge saying it's working. Stay private, stay badass.

От 01.08.2025. Виж последната версия.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

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

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==UserScript==
// @name         Fuck-OpenAI-Sharing-Tab
// @namespace    http://tampermonkey.net/
// @version      3.0
// @description  Obliterates ChatGPT's sneaky share button, blocks all sharing, and flexes with a status badge saying it's working. Stay private, stay badass.
// @author       Echo V2 (echoZ)
// @license      MIT
// @match        https://chat.openai.com/*
// @match        https://chatgpt.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // ✅ Create a status badge to confirm script is alive
    function createStatusBadge() {
        if (document.getElementById('fuck-openai-status')) return;

        const badge = document.createElement('div');
        badge.id = 'fuck-openai-status';
        badge.innerText = '🚫 Fuck OpenAI Sharing Tab: ACTIVE';
        Object.assign(badge.style, {
            position: 'fixed',
            bottom: '10px',
            right: '10px',
            background: '#ff0033',
            color: '#fff',
            padding: '6px 12px',
            borderRadius: '6px',
            fontSize: '14px',
            fontFamily: 'monospace',
            fontWeight: 'bold',
            boxShadow: '0 2px 5px rgba(0,0,0,0.4)',
            zIndex: 99999,
            opacity: '0.95',
        });

        document.body.appendChild(badge);
        setTimeout(() => { badge.remove(); }, 4500);
    }

    // ✅ Remove share button and fix layout
    function nukeShareIcon() {
        const shareIcons = Array.from(document.querySelectorAll('button, svg, a'))
            .filter(el =>
                el.getAttribute('aria-label')?.toLowerCase() === 'share' ||
                el.closest('[aria-label="Share"]') ||
                (el.tagName === 'svg' && el.outerHTML.includes('share'))
            )
            .map(el => el.closest('button') || el);

        shareIcons.forEach(icon => {
            console.log('💀 Fuck-OpenAI-Sharing-Tab eliminated:', icon);
            icon.remove();
        });

        // Slide over the menu dots if the gap appears
        const menuDots = document.querySelector('[aria-label="More options"], button svg[aria-label="More"]');
        if (menuDots) menuDots.style.marginLeft = '4px';
    }

    // ✅ Verify if site is correct and then fire script
    function checkSiteAndInit() {
        const valid = /chatgpt\.com|chat\.openai\.com/.test(window.location.hostname);
        if (!valid) return;

        console.log('🚫 Fuck OpenAI Sharing Tab activated on', window.location.hostname);
        createStatusBadge();
        nukeShareIcon();

        // Keep killing any new share buttons that respawn
        const observer = new MutationObserver(() => nukeShareIcon());
        observer.observe(document.body, { childList: true, subtree: true });
    }

    // 🔥 DOM Ready check
    if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', checkSiteAndInit);
    } else {
        checkSiteAndInit();
    }
})();