Enable Text Selection and Get Cookies

Adds draggable buttons to enable text selection and get cookies of the current page

// ==UserScript==
// @name         Enable Text Selection and Get Cookies
// @namespace    https://greasyfork.org/users/296362
// @version      24.09.12.0
// @author       Lancelotly.Sagirrarimeow
// @description  Adds draggable buttons to enable text selection and get cookies of the current page
// @match        *://*/*
// @noframes
// @exclude      https://*.figma.com/*
// @exclude      https://*.google.com/*
// @icon         
// @grant        GM.cookie
// @run-at       document-idle
// @connect      *
// ==/UserScript==

(function () {
    'use strict';

    let enableCopyButton;
    let cookieButton;
    let cookieCleanButton;
    let isClicked = false;

    function enableTextSelection(e) {
        e.stopPropagation();
        e.stopImmediatePropagation && e.stopImmediatePropagation();

        applyTextSelection();
        const events = ['copy', 'cut', 'contextmenu', 'selectstart', 'mousedown', 'mouseup', 'mousemove', 'keydown', 'keypress', 'keyup'];
        events.forEach(event => {
            document.documentElement.addEventListener(event, stopPropagation, {capture: true});

        });
        alert('Text selection enabled!');

        isClicked = true;
        enableCopyButton.innerText = '🔓';
        enableCopyButton.removeEventListener('click', enableTextSelection);
    }

    function applyTextSelection() {
        document.querySelectorAll('*').forEach(function (element) {
            if (window.getComputedStyle(element, null).getPropertyValue('user-select') === 'none') {
                element.style.setProperty('user-select', 'text', 'important');
            }
        });
    }

    async function getCookieString() {
        //const cookies = document.cookie;
        //const cookies = await cookieStore.getAll();
        const cs = await GM.cookie.list({ url: window.location.host, partitionKey: {} });
        console.log(cs);

        const cookieString = Object.values(cs).map(cookie => {
            return `${cookie.name}=${cookie.value}`;
        }).join('; ');

        prompt("Cookie Data:", cookieString);

        const name = prompt("Enter the localStorage name you'd like to access:", "access_token");
        const localStorageItem = localStorage.getItem(name);
        prompt("localStorageItem:", localStorageItem);
    }

    function cleanWebsite() {
        const hostname = document.location.hostname;
        // Clear cookies
        document.cookie.split(';').forEach(cookie => {
            const [name, , domain] = cookie.trim().split(/=| |\./);
            //if (domain === document.location.hostname) {
                document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:01 GMT; path=/; domain=${domain};`;
            //}
        });
        localStorage.clear();
        alert('First-party cookies, domain localStorage cleared!');
        location.reload();
    }

    function stopPropagation(event) {
        event.stopPropagation();
        event.stopImmediatePropagation && event.stopImmediatePropagation();
    }

    function findMaxZindex() {
        const zIndexes = [];
        document
            .querySelectorAll("*")
            .forEach(el => {
            const zIndex = parseInt(window.getComputedStyle(el).zIndex, 10);
            if (!isNaN(zIndex)) {
                zIndexes.push(zIndex);
            }
        });
        return Math.max.apply(1, zIndexes);
    }


    function makeDraggable(button) {
        let isDragging = false;
        let startX, startY, startLeft, startTop;

        function onMousedown(e) {
            isDragging = true;
            startX = e.clientX;
            startY = e.clientY;
            startLeft = button.offsetLeft;
            startTop = button.offsetTop;
            document.addEventListener('mousemove', onMousemove);
            document.addEventListener('mouseup', onMouseup);
        }

        function onMousemove(e) {
            if (isDragging) {
                const dx = e.clientX - startLeft;
                const dy = e.clientY - startTop;
                moveButtonBy(dx, dy);
            }
        }

        function moveButtonBy(dx, dy) {
            button.style.transform = `translate(${dx}px, ${dy}px)`;
        }

        function onMouseup(e) {
            isDragging = false;
            startX = e.clientX;
            startY = e.clientY;
            startLeft = button.offsetLeft;
            startTop = button.offsetTop;
            document.removeEventListener('mousemove', onMousemove);
            document.removeEventListener('mouseup', onMouseup);
        }

        button.addEventListener('mousedown', onMousedown);
    }

    ///////
    const hoverStyle = {
        right: 0,
    };

    const enableCopyStyle = {
        position: 'fixed',
        top: '80%',
        right: '-0.5rem',
        transform: 'translateY(-50%)',
        zIndex: findMaxZindex() + 1,
        transition: 'right 0.3s ease-in-out',
    }

    const cookieStyle = {
        position: 'fixed',
        top: '85%',
        right: '-0.5rem',
        transform: 'translateY(-50%)',
        zIndex: findMaxZindex() + 1,
        transition: 'right 0.3s ease-in-out',
    }

    const cleanWebsiteDataStyle = {
        position: 'fixed',
        top: '90%',
        right: '-0.5rem',
        transform: 'translateY(-50%)',
        zIndex: findMaxZindex() + 1,
        transition: 'right 0.3s ease-in-out',
    }

    function addButton() {
        const enableCopyButton = document.createElement('button');
        enableCopyButton.classList.add('enable-copy-button');
        Object.assign(enableCopyButton.style, enableCopyStyle);
        enableCopyButton.innerText = '🔓';
        enableCopyButton.addEventListener('click', enableTextSelection);
        enableCopyButton.addEventListener('mouseenter', () => Object.assign(enableCopyButton.style, hoverStyle));
        enableCopyButton.addEventListener('mouseleave', () => Object.assign(enableCopyButton.style, enableCopyStyle));

        const cookieButton = document.createElement('button');
        cookieButton.classList.add('cookie-button');
        Object.assign(cookieButton.style, cookieStyle);
        cookieButton.innerText = '🍪';
        cookieButton.addEventListener('click', getCookieString);
        cookieButton.addEventListener('mouseenter', () => Object.assign(cookieButton.style, hoverStyle));
        cookieButton.addEventListener('mouseleave', () => Object.assign(cookieButton.style, cookieStyle));

        const cleanWebsiteData = document.createElement('button');
        cleanWebsiteData.classList.add('cookie-button');
        Object.assign(cleanWebsiteData.style, cleanWebsiteDataStyle);
        cleanWebsiteData.innerText = '🧹';
        cleanWebsiteData.addEventListener('click', cleanWebsite);
        cleanWebsiteData.addEventListener('mouseenter', () => Object.assign(cleanWebsiteData.style, hoverStyle));
        cleanWebsiteData.addEventListener('mouseleave', () => Object.assign(cleanWebsiteData.style, cleanWebsiteDataStyle));

        document.body.append(enableCopyButton, cookieButton, cleanWebsiteData);
        makeDraggable(enableCopyButton);
        makeDraggable(cookieButton);
    }

    addButton();

})();