IntelX.io Copy ID

Add a copy button to each search result to copy the data-id attribute

// ==UserScript==
// @name         IntelX.io Copy ID
// @description  Add a copy button to each search result to copy the data-id attribute
// @author       You
// @match        https://intelx.io/*
// @grant        none
// @version      0.2.2
// @namespace    https://greasyfork.org/en/scripts/497675-intelx-copy-id
// @license      MIT
// @icon         
// ==/UserScript==

(function() {
    'use strict';

    function appendCopyButton(element) {
        if (element.querySelector('.copy-btn')) return;


        let copyBtn = document.createElement('button');
        copyBtn.textContent = element.getAttribute('data-id');
        copyBtn.className = 'copy-btn';
        copyBtn.style.marginLeft = '10px';
        copyBtn.onclick = function() {
            navigator.clipboard.writeText(element.getAttribute('data-id'))
                .catch(err => console.error('Error copying data-id:', err));
        };

        element.insertAdjacentElement('afterend', copyBtn);
    }

    const observer = new MutationObserver(mutations => {
        mutations.forEach(mutation => {
            mutation.addedNodes.forEach(node => {
                let detailLink = node.querySelector('.prevResult .view_details');
                if (detailLink) {
                    appendCopyButton(detailLink);
                } else {
                    console.log("Detail link not found within search-result element.");
                }
            });
        });
    });

    observer.observe(document.body, { childList: true, subtree: true });

    document.querySelectorAll('.prevResult .view_details').forEach(element => {
        appendCopyButton(element);
    });
})();