Github preivew Button

An userscript to add "Rawgit" button on github.

目前為 2018-11-01 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

Advertisement:

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

Advertisement:

// ==UserScript==
// @name		Github preivew Button
// @namespace	he
// @description	An userscript to add "Rawgit" button on github.
// @include		https://github.com/*
// @include		https://gist.github.com/*
// @version		8.9.4
// @grant 		none
// ==/UserScript==

/*
https://gist.github.com/eight04/186267c150a2dfc0580a/raw/812fd7b418e0a157f02caa144a15c55c06ced8ac/uao_decode.py
https://rawgit.com/eight04/186267c150a2dfc0580a/raw/812fd7b418e0a157f02caa144a15c55c06ced8ac/uao_decode.py

https://github.com/eight04/linky-square/raw/master/demo.html
https://rawgit.com/eight04/linky-square/master/demo.html
*/

"use strict";

var _BASEURL = 'https://htmlpreview.github.io/?';

function replace() {
    // Check if raw-url button exists
    var btns, i;
    btns = document.querySelectorAll(".file-actions a:not(.rawgit)");
    for (i = 0; i < btns.length; i++) {
        if (btns[i].textContent == "Raw") {
            createButton(btns[i]);
        }
    }
}

function createButton(btn) {
    var url = btn.href;
    if (url.indexOf("gist.github.com") >= 0) {
        url = url.replace(/github\.com\/([^/]+\/[^/]+)\/raw/, "githubusercontent.com/$1");
    } else {
        url = url.replace(/github\.com\/([^/]+\/[^/]+)\/raw/, "raw.githubusercontent.com/$1");
    }

    url = _BASEURL + url;

    var newBtn = btn.cloneNode(false);
    newBtn.href = url;
    newBtn.textContent = "Rawgit";
    newBtn.removeAttribute("id");

    btn.parentNode.insertBefore(newBtn, btn.nextSibling);
    btn.classList.add("rawgit");

    if (!btn.parentNode.classList.contains("btn-group")) {
        var parent = btn.parentNode,
            group = document.createElement("div");
        group.className = "btn-group";
        while (parent.childNodes.length) {
            group.appendChild(parent.childNodes[0]);
        }
        parent.appendChild(group);
    }
}

var container =
    document.querySelector("#js-repo-pjax-container") ||
    document.querySelector("#js-pjax-container");

if (container) {
    new MutationObserver(function () {
        replace();
    }).observe(container, { childList: true, subtree: true });
}

replace();