Link Wrapper

Wraps links with specified protocols in <a> tags.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name              Link Wrapper
// @author             TM
// @namespace    https://trap.jp/
// @version           0.1
// @description     Wraps links with specified protocols in <a> tags.
// @match             *://*/*
// @grant               none
// @license           MIT
// ==/UserScript==

(function() {
    'use strict';

    var regexp_url = /((h?)(ttps?:\/\/[a-zA-Z0-9.\-_@:/~?%&;=+#',()*!]+))/g;

    var wrapLink = function(all, url, h, href) {
        return '<a href="h' + href + '" target="_blank">' + url + '</a><br/>';
    }

    /**
     * 渡されるコンテンツ:
     *   - <div>hoge<div>...<div>fuga</div>
     *  <div>hogefuga</div>
     */
    function wrapLinks(element) {
        var textContent = "";
        if(element.nodeType === 3) {
            textContent = element.textContent;
        }
        else{
            for(var elem of element.childNodes){
                console.log(elem);
                console.log(elem.nodeType);
                if(elem.nodeType === 3) {
                    textContent += elem.textContent;
                }
            }
        }
        if (textContent) {
            var newTextContent = textContent.replace(regexp_url, wrapLink);
            if (newTextContent !== textContent) {
                element.innerHTML = newTextContent;
            }
        }
    }

    function traverseAndWrap(element) {
        if(element.tagName === "A" || element.tagName === "STYLE" || element.tagName === "SCRIPT"){
            return;
        }
        if (element.childNodes.length === 1) {
            console.log(element);
            wrapLinks(element);
        }

        for (var i = 0; i < element.childNodes.length; i++) {
            var childNode = element.childNodes[i];
            if (childNode.nodeType === 1) {
                traverseAndWrap(childNode);
            }
        }

    }

    window.addEventListener('load', function() {
        traverseAndWrap(document.body);
    });
})();