Visible Copy Confirmation Feedback

Provides a visual feedback when you copy text using Ctrl+C.

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         Visible Copy Confirmation Feedback
// @namespace    http://tampermonkey.net/
// @version      1.0.1
// @description  Provides a visual feedback when you copy text using Ctrl+C.
// @author       Donff Roodus
// @match        *://*/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    document.addEventListener('keydown', function(e) {
        if (e.ctrlKey && e.key === 'c') {
            showCopyFeedback();
        }
    });

    function showCopyFeedback() {
        // Create the feedback element
        let feedbackElement = document.createElement('div');
        feedbackElement.textContent = 'Copied to clipboard!';
        document.body.appendChild(feedbackElement);

        // Style the feedback element
        Object.assign(feedbackElement.style, {
            position: 'fixed',
            top: '20px',
            right: '20px',
            backgroundColor: '#4CAF50',
            color: 'white',
            padding: '15px',
            borderRadius: '5px',
            zIndex: '9999',
            fontSize: '16px',
            opacity: '0',
            transition: 'opacity 0.5s'
        });

        // Animate the feedback
        setTimeout(() => {
            feedbackElement.style.opacity = '1';
        }, 10);

        // Remove the feedback element after a few seconds
        setTimeout(() => {
            feedbackElement.style.opacity = '0';
            setTimeout(() => {
                document.body.removeChild(feedbackElement);
            }, 500);
        }, 2000);
    }
})();