Copy HTML to Anki

Copy entire HTML of a webpage and send it to Anki, converting relative URLs to absolute URLs. Trigger with Ctrl+Shift+Y or via Tampermonkey menu.

Versión del día 10/07/2024. Echa un vistazo a la versión más reciente.

// ==UserScript==
// @name         Copy HTML to Anki
// @namespace    http://tampermonkey.net/
// @version      1.8
// @description  Copy entire HTML of a webpage and send it to Anki, converting relative URLs to absolute URLs. Trigger with Ctrl+Shift+Y or via Tampermonkey menu.
// @author       nabe
// @match        *://*/*
// @grant        GM_xmlhttpRequest
// @grant        GM_registerMenuCommand
// @connect      localhost
// @run-at       document-end
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    function copyHtmlToAnki() {
        console.log("copyHtmlToAnki function triggered");

        // Function to convert relative URLs to absolute URLs
        function makeAbsolute(url) {
            console.log("Converting URL to absolute:", url);
            return new URL(url, document.baseURI).href;
        }

        // Clone the document to manipulate it
        let docClone = document.documentElement.cloneNode(true);
        console.log("Document cloned");

        // Convert all relative URLs to absolute URLs
        let elements = docClone.querySelectorAll('[src], [href]');
        elements.forEach(function(element) {
            if (element.hasAttribute('src')) {
                element.setAttribute('src', makeAbsolute(element.getAttribute('src')));
            }
            if (element.hasAttribute('href')) {
                element.setAttribute('href', makeAbsolute(element.getAttribute('href')));
            }
        });

        let htmlContent = docClone.outerHTML;
        console.log("HTML content copied with absolute URLs:", htmlContent);

        GM_xmlhttpRequest({
            method: "POST",
            url: "http://localhost:8765",
            data: JSON.stringify({
                "action": "addNote",
                "version": 6,
                "params": {
                    "note": {
                        "deckName": "Default",
                        "modelName": "htmlcard",
                        "fields": {
                            "HTML": htmlContent
                        },
                        "tags": ["newimport"]
                    }
                }
            }),
            headers: {
                "Content-Type": "application/json"
            },
            onload: function(response) {
                console.log("Response from AnkiConnect:", response);
                if (response.status === 200) {
                    console.log("HTML content sent to Anki!");
                } else {
                    console.error("Failed to send content to Anki. Response:", response);
                }
            },
            onerror: function(error) {
                console.error("Error sending content to Anki:", error);
            }
        });
    }

    // Add event listener for the keyboard shortcut (Ctrl+Shift+Y)
    document.addEventListener('keydown', function(event) {
        console.log("Keydown event detected:", event);
        if (event.ctrlKey && event.shiftKey && event.code === 'KeyY') {
            console.log("Ctrl+Shift+Y detected");
            copyHtmlToAnki();
        }
    });

    // Register the menu command to Tampermonkey menu
    GM_registerMenuCommand("Copy HTML to Anki", function() {
        console.log("Menu command selected");
        copyHtmlToAnki();
    });

    console.log("Copy HTML to Anki script loaded");
})();