Iconfont自由复制

copy paste in the iconfont

// ==UserScript==
// @name         Iconfont自由复制
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  copy paste in the iconfont
// @author       You
// @run-at	     document-end
// @match        https://www.iconfont.cn/*
// @icon 
// @grant    GM_setClipboard
// @license MIT
// ==/UserScript==

function htmlToElement(html) {
    var template = document.createElement('template');
    html = html.trim(); // Never return a text node of whitespace as the result
    template.innerHTML = html;
    return template.content.firstChild;
}

let wait = null
function run() {
    const covers = document.querySelectorAll(".main .icon-cover")
    if (!covers || !covers.length) {
        return
    }
    const checkMark = document.querySelector(".btn-extra")
    if (checkMark) return // page hasn't changed.

    console.log("patch applied")
    const ElCopySvg = '<span title="复制" class="cover-item iconfont cover-item-line icon-fuzhidaima btn-extra"></span>' // icon to copy
    covers.forEach(c=>{
        const el = htmlToElement(ElCopySvg)
        el.addEventListener("click", copySVG);
        c.appendChild(el)
    })
}

function getBase64Image(img) {
    // Create an empty canvas element
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;

    // Copy the image contents to the canvas
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);

    // Get the data-URL formatted image
    // Firefox supports PNG and JPEG. You could check img.src to
    // guess the original format, but be aware the using "image/jpg"
    // will re-encode the image.
    var dataURL = canvas.toDataURL("image/png");

    return dataURL.replace(/^data:image\/(png|jpg);base64,/, "");
}

function copySVG(el) {
    const svg = this.parentElement.parentElement.querySelector(".icon-twrap svg")
    const img = this.parentElement.parentElement.querySelector(".icon-twrap img")
    if (!svg && !img) return
    if (svg) {
        const text = svg.outerHTML;
        GM_setClipboard(text)
    } else {
        //const imgEncoded = getBase64Image(img)
        //console.log(imgEncoded)
        GM_setClipboard(img.src)
    }
    this.classList.remove("icon-fuzhidaima")
    this.classList.add("icon-ok")
    setTimeout(()=>{
        this.classList.remove("icon-ok")
        this.classList.add("icon-fuzhidaima")
    }, 1000);
}

function addCSS(css) {
    if (typeof GM_addStyle != "undefined") {
        GM_addStyle(css);
    } else if (typeof PRO_addStyle != "undefined") {
        PRO_addStyle(css);
    } else if (typeof addStyle != "undefined") {
        addStyle(css);
    } else {
        var node = document.createElement("style");
        node.type = "text/css";
        node.appendChild(document.createTextNode(css));
        var heads = document.getElementsByTagName("head");
        if (heads.length > 0) {
            heads[0].appendChild(node);
        } else {
            // no head yet, stick it whereever
            document.documentElement.appendChild(node);
        }
    }
}

function observer(){
    const wrapper = document.querySelector(".wrapper")
    if (!wrapper) {
        setTimeout(observer, 200);
        return
    }
    console.log("observing")
    /// ---------------------------------
    /// mutation observer -monitors the Posts grid for infinite scrolling event-.
    /// ---------------------------------
    const observer1 = new MutationObserver(function(mutations) {
        if (mutations[0].target.classList.contains("icon-cover")) {
            console.log("change ignored")
            return
        }
        wait && clearTimeout(wait)
        wait = setTimeout(run, 200)
        console.log("changed")
    }).observe(document.querySelector('.wrapper'),     // target of the observer
     {
        // attributes: true,
        childList: true,
        subtree: true
        // characterData: true,
    }); // config of the observer
}

(function() {
    'use strict';
    observer();

    const css = `
    .block-icon-list li .icon-cover {
    height: auto;
    }
`
    addCSS(css)
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址