github在线编辑/运行

github跳转github1s和gitpod

// ==UserScript==
// @name              github在线编辑/运行
// @namespace         http://tampermonkey.net/
// @version           1.0
// @description       github跳转github1s和gitpod
// @icon              
// @author            w__yi
// @match             https://*.github.com/*/*
// @require           https://cdn.bootcdn.net/ajax/libs/jquery/3.2.1/jquery.min.js
// @grant             none
// @charset		      UTF-8
// @license           GPL License
// ==/UserScript==

const util = (function () {

    function findTargetElement(targetContainer) {
        const body = window.document;
        let tabContainer;
        let tryTime = 0;
        const maxTryTime = 120;
        return new Promise((resolve, reject) => {
            let interval = setInterval(() => {
                tabContainer = body.querySelector(targetContainer);
                if (tabContainer) {
                    clearInterval(interval);
                    resolve(tabContainer);
                }
                if ((++tryTime) === maxTryTime) {
                    clearInterval(interval);
                    reject();
                }
            }, 500);
        });
    }

    return {
        findTargetEle: (targetEle) => findTargetElement(targetEle)
    }
})();

const _CONFIG_ = {
    matchData: {
        GitHub: /github/
    }
};

const consumer = (function () {

    class BaseConsumer {
        call() {
        }

        github1s() {
            let btn = document.createElement('button');
            btn.innerText = 'github1s'
            btn.className = 'btn btn-primary ml-2';
            btn.onclick = function () {
                window.open(`${"https://github1s.com" + window.location.pathname}`);
            };
            return btn;
        }

        gitpod() {
            let btn = document.createElement('button');
            btn.innerText = 'gitpod'
            btn.className = 'btn btn-primary ml-2';
            btn.onclick = function () {
                window.open(`${"https://gitpod.io/#" + window.location.href}`);
            };
            return btn;
        }
    }


    class GitHubConsumer extends BaseConsumer {
        call() {
            util.findTargetEle('.file-navigation')
                .then((container) => {
                    container.append(this.github1s());
                    container.append(this.gitpod());
                })
                .catch(e => console.warn("页面加载不成功!", e));
        }
    }

    return {
        callConsumer: (path) => {
            let mallCase = undefined;
            for (let pattern in _CONFIG_.matchData) {
                if (_CONFIG_.matchData[pattern].test(path)) {
                    mallCase = pattern;
                    break;
                }
            }
            if (mallCase === undefined) {
                return;
            }
            const targetConsumer = eval(`new ${mallCase}Consumer`);
            targetConsumer.call();
        }
    }

})();

(function () {
    consumer.callConsumer(window.location);
})();