Grayscale Toggle with Persistence

Toggles grayscale on the webpage with Alt+G and remembers the state

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @name         Grayscale Toggle with Persistence
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Toggles grayscale on the webpage with Alt+G and remembers the state
// @author       Drewby123
// @match        *://*/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    const STORAGE_KEY = 'grayscaleToggleState';

    // Retrieve and apply the saved grayscale state on page load
    let isGrayscale = localStorage.getItem(STORAGE_KEY) === 'true';
    document.body.style.filter = isGrayscale ? 'grayscale(100%)' : 'none';

    // Listen for the Alt+G key combination to toggle grayscale
    document.addEventListener('keydown', (e) => {
        if (e.altKey && e.key.toLowerCase() === 'g') {
            isGrayscale = !isGrayscale;
            document.body.style.filter = isGrayscale ? 'grayscale(100%)' : 'none';

            // Save the current state to localStorage
            localStorage.setItem(STORAGE_KEY, isGrayscale);
        }
    });
})();