EmailHunter - Auto Email Extractor

Automatically extracts emails from any web page and displays a floating button.

// ==UserScript==
// @name         EmailHunter - Auto Email Extractor
// @namespace    http://tampermonkey.net/
// @version      0.5
// @description  Automatically extracts emails from any web page and displays a floating button.
// @author       You
// @match        *://*/*
// @icon         
// @grant        GM_addStyle
// @grant        GM_setClipboard
// @run-at       document-end
// @license      Copyright (c) 2025 ominipcba.
// ==/UserScript==

(function() {
    'use strict';

    if (!document.body) {
        console.warn("EmailHunter: document.body not found. Script will not run on this page.");
        return;
    }

    let foundEmails = new Set();
    let emailDisplayButton;
    let modal;

    function extractEmailsFromText(text) {
        const emailRegex = /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g;
        return text.match(emailRegex) || [];
    }

    function scanPageForEmails() {
        const newEmails = extractEmailsFromText(document.body.innerText);
        let updated = false;
        newEmails.forEach(email => {
            if (!foundEmails.has(email)) {
                foundEmails.add(email);
                updated = true;
            }
        });

        if (updated) {
            updateEmailDisplayButton();
        }
    }

    function createEmailDisplayButton() {
        if (emailDisplayButton) return;

        emailDisplayButton = document.createElement('div');
        emailDisplayButton.id = 'email-extractor-button';
        emailDisplayButton.innerText = 'Emails: 0';
        document.body.appendChild(emailDisplayButton);

        emailDisplayButton.addEventListener('click', showEmailList);

        GM_addStyle(`
            #email-extractor-button {
                position: fixed;
                bottom: 20px;
                right: 20px;
                background-color: #007bff;
                color: white;
                padding: 10px 15px;
                border-radius: 25px;
                cursor: pointer;
                z-index: 9999;
                font-family: sans-serif;
                font-size: 14px;
                box-shadow: 0 4px 8px rgba(0,0,0,0.2);
                transition: background-color 0.3s;
            }
            #email-extractor-button:hover {
                background-color: #0056b3;
            }
        `);
    }

    function updateEmailDisplayButton() {
        if (!emailDisplayButton) {
            createEmailDisplayButton();
        }
        emailDisplayButton.innerText = `Emails: ${foundEmails.size}`;
    }

    function showEmailList() {
        if (modal) {
            modal.remove();
        }

        modal = document.createElement('div');
        modal.id = 'email-extractor-modal';

        const emailArray = Array.from(foundEmails);
        const emailsHtml = emailArray.length > 0 ? emailArray.join('<br>') : 'No emails found yet.';

        modal.innerHTML = `
            <div class="modal-content">
                <span class="close-button">&times;</span>
                <h2><a href="https://www.ominipcba.com" target="_blank" rel="noopener noreferrer">ominipcba.com</a> - Found Emails (${emailArray.length})</h2>
                <div class="email-list">${emailsHtml}</div>
                <button id="copy-emails-button">Copy All</button>
            </div>
        `;

        document.body.appendChild(modal);

        modal.querySelector('.close-button').addEventListener('click', () => modal.remove());
        modal.querySelector('#copy-emails-button').addEventListener('click', () => {
            GM_setClipboard(emailArray.join(', '));
            alert('Emails copied to clipboard!');
        });

        GM_addStyle(`
            #email-extractor-modal {
                position: fixed;
                z-index: 10000;
                left: 0;
                top: 0;
                width: 100%;
                height: 100%;
                background-color: rgba(0,0,0,0.5);
                display: flex;
                align-items: center;
                justify-content: center;
            }
            .modal-content {
                background-color: #fefefe;
                padding: 20px;
                border: 1px solid #888;
                width: 80%;
                max-width: 500px;
                border-radius: 8px;
                box-shadow: 0 4px 8px rgba(0,0,0,0.2);
                font-family: sans-serif;
            }
            .close-button {
                color: #aaa;
                float: right;
                font-size: 28px;
                font-weight: bold;
                cursor: pointer;
            }
            .email-list {
                margin-top: 15px;
                margin-bottom: 15px;
                max-height: 300px;
                overflow-y: auto;
                border: 1px solid #ddd;
                padding: 10px;
                border-radius: 4px;
                word-break: break-all;
            }
            #copy-emails-button {
                background-color: #28a745;
                color: white;
                padding: 10px 15px;
                border: none;
                border-radius: 4px;
                cursor: pointer;
            }
            #copy-emails-button:hover {
                background-color: #218838;
            }
        `);
    }

    // Initial scan
    scanPageForEmails();

    // Observe DOM changes for dynamically loaded content
    const observer = new MutationObserver(scanPageForEmails);
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();