wblinkable

让网页版微博的链接可以在新标签页打开

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @license      MIT
// @name         wblinkable
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  让网页版微博的链接可以在新标签页打开
// @author       xiongchengqing
// @match        https://m.weibo.cn/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=weibo.cn
// @run-at       document-end
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // 让 github.com 的文本可以点击
    function makeGithubTextLinkable(node) {
        const REGEX = /(((https?:)?\/?\/\/)?([0-9a-z_\-]+\.)?[0-9a-z_\-]+\.[0-9a-z_\-]+\/[0-9a-z_\-\/\.]*)/ig;
        let innerHTMLCopy = node.innerHTML
        let res;

        while((res = REGEX.exec(node.innerHTML)) !== null) {
            if (
                !res[0].startsWith('https://') &&
                !res[0].startsWith('http://') &&
                !res[0].startsWith('//') &&
                !res[0].startsWith('://')
            ) {
                innerHTMLCopy = innerHTMLCopy.replace(res[0], `<a href="https://${res[0]}" target="_blank">${res[0]}</a>`);
            }
        };

        node.innerHTML = innerHTMLCopy;
        node.classList.add('handled');
    }

    // 扫描微博文本并处理
    function curryHandleTweet() {
        let nodes = null;
        let id = null;

        return function() {
            if (id) return;
            const promise = new Promise((resolve) => {
                id = setInterval(() => {
                    nodes = document.querySelectorAll('.weibo-text');
                    if (nodes && nodes.length) {
                        nodes = Array.from(nodes).filter(node => !node.classList.contains('handled'));
                        if (nodes.length) {
                            for (const item of nodes) {
                                makeGithubTextLinkable(item);
                            }
                        }
                    }

                    if (!nodes.length) resolve();
                }, 100);
            }).then(() => {
                clearInterval(id);
                id = null;
            });
        };
    }

    const handleTweet = curryHandleTweet();

    window.addEventListener('scroll', handleTweet);
    window.addEventListener('pushState', handleTweet);
    window.addEventListener('popstate', handleTweet);
    handleTweet();
})(window);