gist github look fix

gist.githubのembedの外見を修正

Versión del día 6/9/2020. Echa un vistazo a la versión más reciente.

Tendrás que instalar una extensión para tu navegador como Tampermonkey, Greasemonkey o Violentmonkey si quieres utilizar este script.

Necesitarás instalar una extensión como Tampermonkey o Violentmonkey para instalar este script.

Necesitarás instalar una extensión como Tampermonkey o Violentmonkey para instalar este script.

Necesitarás instalar una extensión como Tampermonkey o Userscripts para instalar este script.

Necesitará instalar una extensión como Tampermonkey para instalar este script.

Necesitarás instalar una extensión para administrar scripts de usuario si quieres instalar este script.

(Ya tengo un administrador de scripts de usuario, déjame instalarlo)

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión como Stylus para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

Necesitará instalar una extensión del gestor de estilos de usuario para instalar este estilo.

(Ya tengo un administrador de estilos de usuario, déjame instalarlo)

// ==UserScript==
// @name         gist github look fix
// @namespace    https://github.com/fushihara/github-gist-look-fix
// @match        https://nomatch.example.com
// @description  gist.githubのembedの外見を修正
// @version      1.0.2
// @grant        none
// @license      MIT
// @source       https://github.com/fushihara/github-gist-look-fix
// @homepage     https://greasyfork.org/ja/scripts/410890
// @noframes
// ==/UserScript==
/******/ (function(modules) { // webpackBootstrap
/******/ 	// The module cache
/******/ 	var installedModules = {};
/******/
/******/ 	// The require function
/******/ 	function __webpack_require__(moduleId) {
/******/
/******/ 		// Check if module is in cache
/******/ 		if(installedModules[moduleId]) {
/******/ 			return installedModules[moduleId].exports;
/******/ 		}
/******/ 		// Create a new module (and put it into the cache)
/******/ 		var module = installedModules[moduleId] = {
/******/ 			i: moduleId,
/******/ 			l: false,
/******/ 			exports: {}
/******/ 		};
/******/
/******/ 		// Execute the module function
/******/ 		modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ 		// Flag the module as loaded
/******/ 		module.l = true;
/******/
/******/ 		// Return the exports of the module
/******/ 		return module.exports;
/******/ 	}
/******/
/******/
/******/ 	// expose the modules object (__webpack_modules__)
/******/ 	__webpack_require__.m = modules;
/******/
/******/ 	// expose the module cache
/******/ 	__webpack_require__.c = installedModules;
/******/
/******/ 	// define getter function for harmony exports
/******/ 	__webpack_require__.d = function(exports, name, getter) {
/******/ 		if(!__webpack_require__.o(exports, name)) {
/******/ 			Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ 		}
/******/ 	};
/******/
/******/ 	// define __esModule on exports
/******/ 	__webpack_require__.r = function(exports) {
/******/ 		if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ 			Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ 		}
/******/ 		Object.defineProperty(exports, '__esModule', { value: true });
/******/ 	};
/******/
/******/ 	// create a fake namespace object
/******/ 	// mode & 1: value is a module id, require it
/******/ 	// mode & 2: merge all properties of value into the ns
/******/ 	// mode & 4: return value when already ns object
/******/ 	// mode & 8|1: behave like require
/******/ 	__webpack_require__.t = function(value, mode) {
/******/ 		if(mode & 1) value = __webpack_require__(value);
/******/ 		if(mode & 8) return value;
/******/ 		if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ 		var ns = Object.create(null);
/******/ 		__webpack_require__.r(ns);
/******/ 		Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ 		if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ 		return ns;
/******/ 	};
/******/
/******/ 	// getDefaultExport function for compatibility with non-harmony modules
/******/ 	__webpack_require__.n = function(module) {
/******/ 		var getter = module && module.__esModule ?
/******/ 			function getDefault() { return module['default']; } :
/******/ 			function getModuleExports() { return module; };
/******/ 		__webpack_require__.d(getter, 'a', getter);
/******/ 		return getter;
/******/ 	};
/******/
/******/ 	// Object.prototype.hasOwnProperty.call
/******/ 	__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ 	// __webpack_public_path__
/******/ 	__webpack_require__.p = "";
/******/
/******/
/******/ 	// Load entry module and return exports
/******/ 	return __webpack_require__(__webpack_require__.s = "./src/index.ts");
/******/ })
/************************************************************************/
/******/ ({

/***/ "./src/gitsTool.ts":
/*!*************************!*\
  !*** ./src/gitsTool.ts ***!
  \*************************/
/*! exports provided: GistTools */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GistTools", function() { return GistTools; });
const styleRuleInsertLog = new WeakMap();
class GistTools {
    constructor(files) {
        this.files = files;
    }
    static getInstance(element) {
        GistTools.insertStyleRule();
        const files = [];
        for (let e of element.children) {
            if (!e.classList.contains("gist-file") || !(e instanceof HTMLDivElement)) {
                return null;
            }
            files.push(new OneFile(e));
        }
        return new GistTools(files);
    }
    /** documentにcssのルールを定義する。何度呼んでも良い */
    static insertStyleRule() {
        if (styleRuleInsertLog.has(document)) {
            return;
        }
        styleRuleInsertLog.set(document, true);
        const styleEl = document.createElement('style');
        document.head.appendChild(styleEl);
        styleEl.sheet.insertRule(".gist .header{display:flex;font-size: 12px;align-items: center;}");
        styleEl.sheet.insertRule(".gist .header >* {padding:0 3px;}");
        styleEl.sheet.insertRule(".gist .header .filename{font-family: monospace;padding:0 10px;}");
        styleEl.sheet.insertRule(".gist .header .space{flex:1 1 0;}");
        styleEl.sheet.insertRule(".gist .header button{line-height: 13px;}");
        styleEl.sheet.insertRule(".gist .gist-data{border-radius:0 0 6px 6px !important;}");
        styleEl.sheet.insertRule(".gist .blob-num{line-height: 13px !important;}");
        styleEl.sheet.insertRule(".gist .blob-code{line-height: 13px !important;}");
    }
}
class OneFile {
    constructor(element) {
        this.element = element;
        const footerData = this.getFooterData(element.querySelector(".gist-meta"));
        this.fileName = footerData.fileName;
        this.fileLink = footerData.fileLink;
        this.fileRawLink = footerData.fileRawLink;
        this.repoLink = footerData.repoLink;
        this.gistId = footerData.gistId;
        this.textValue = this.getInnerText(element.querySelector(".gist-data"));
        const topBrotherElement = document.createElement("div");
        topBrotherElement.classList.add("header");
        topBrotherElement.innerHTML = `
    <div class="filename">hoge.txt</div>
    <div class="space"></div>
    <a class="file-link" href="http://example.com">file</a>
    <a class="raw-link" href="http://example.com">raw</a>
    <a class="repo-link" href="http://example.com">repo</a>
    <a class="edit-link" href="http://example.com">edit</a>
    <button filename>filename</button>
    <button text>text</button>
    <button git-clone>git clone command</button>
    <button download-zip-repo style="display:none;">download zip repo</button>
    `;
        topBrotherElement.querySelector(".filename").innerText = this.fileName;
        topBrotherElement.querySelector(".file-link").href = this.fileLink;
        topBrotherElement.querySelector(".raw-link").href = this.fileRawLink;
        topBrotherElement.querySelector(".repo-link").href = this.repoLink;
        topBrotherElement.querySelector(".edit-link").href = this.repoLink + "/edit";
        topBrotherElement.querySelector("[filename]").setAttribute("title", this.fileName);
        topBrotherElement.querySelector("[filename]").addEventListener("click", () => { this.copyText(this.fileName); });
        topBrotherElement.querySelector("[text]").setAttribute("title", this.textValue);
        topBrotherElement.querySelector("[text]").addEventListener("click", () => { this.copyText(this.textValue); });
        topBrotherElement.querySelector("[git-clone]").setAttribute("title", `git clone [email protected]:${this.gistId}.git .`);
        topBrotherElement.querySelector("[git-clone]").addEventListener("click", () => { this.copyText(`git clone [email protected]:${this.gistId}.git .`); });
        topBrotherElement.querySelector("[download-zip-repo]").setAttribute("title", `download zip file`);
        topBrotherElement.querySelector("[download-zip-repo]").addEventListener("click", () => { alert("wip"); });
        element.insertBefore(topBrotherElement, element.children[0]);
        // hide footer
        element.querySelector(".gist-meta").style.display = "none";
    }
    getInnerText(bodyElement) {
        return bodyElement.innerText.split(/\n/).map(a => {
            return a.replace(/^\t/, "");
        }).join("\n");
    }
    copyText(text) {
        navigator.clipboard.writeText(text);
    }
    /** 元のgistのfooterのエレメントから必要な情報を返す */
    getFooterData(footerElement) {
        const fileRawLink = footerElement.children[0].getAttribute("href");
        if (fileRawLink == null) {
            throw new Error();
        }
        let m;
        if (!(m = fileRawLink.match(/(^.+?gist\.github\.com\/.+?)\/raw\//))) {
            throw new Error();
        }
        const repoLink = m[1];
        if (!(m = repoLink.match(/(\w+)$/))) {
            throw new Error("gist hash id not found");
        }
        const gistId = m[1];
        const fileLink = footerElement.children[1].href;
        const fileName = footerElement.children[1].innerText;
        return { fileRawLink, repoLink, gistId, fileName, fileLink };
    }
}


/***/ }),

/***/ "./src/index.ts":
/*!**********************!*\
  !*** ./src/index.ts ***!
  \**********************/
/*! no exports provided */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var _gitsTool__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./gitsTool */ "./src/gitsTool.ts");

init();
function init() {
    const elments = document.querySelectorAll(".gist");
    for (let element of elments) {
        if (element instanceof HTMLDivElement) {
            _gitsTool__WEBPACK_IMPORTED_MODULE_0__["GistTools"].getInstance(element);
        }
    }
}


/***/ })

/******/ });
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/gitsTool.ts","webpack:///./src/index.ts"],"names":[],"mappings":"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","file":"script.user.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/index.ts\");\n","const styleRuleInsertLog: WeakMap<Document, boolean> = new WeakMap();\nexport class GistTools {\n  public static getInstance(element: HTMLDivElement): GistTools | null {\n    GistTools.insertStyleRule();\n    const files: OneFile[] = [];\n    for (let e of element.children) {\n      if (!e.classList.contains(\"gist-file\") || !(e instanceof HTMLDivElement)) {\n        return null;\n      }\n      files.push(new OneFile(e));\n    }\n    return new GistTools(files);\n  }\n  /** documentにcssのルールを定義する。何度呼んでも良い */\n  private static insertStyleRule() {\n    if (styleRuleInsertLog.has(document)) {\n      return;\n    }\n    styleRuleInsertLog.set(document, true);\n    const styleEl = document.createElement('style');\n    document.head.appendChild(styleEl);\n    styleEl.sheet.insertRule(\".gist .header{display:flex;font-size: 12px;align-items: center;}\");\n    styleEl.sheet.insertRule(\".gist .header >* {padding:0 3px;}\");\n    styleEl.sheet.insertRule(\".gist .header .filename{font-family: monospace;padding:0 10px;}\");\n    styleEl.sheet.insertRule(\".gist .header .space{flex:1 1 0;}\");\n    styleEl.sheet.insertRule(\".gist .header button{line-height: 13px;}\");\n    styleEl.sheet.insertRule(\".gist .gist-data{border-radius:0 0 6px 6px !important;}\");\n    styleEl.sheet.insertRule(\".gist .blob-num{line-height: 13px !important;}\");\n    styleEl.sheet.insertRule(\".gist .blob-code{line-height: 13px !important;}\");\n  }\n  private constructor(private readonly files: OneFile[]) {\n  }\n}\nclass OneFile {\n  /** ファイル名 */\n  private fileName: string;\n  /** ファイルへのリンク https://gist.github.com/xxxx/xxxx#xxxx */\n  private fileLink: string;\n  /** ファイルの中身への直リンク https://gist.githubusercontent.com/xxxxx/xxxxxx/raw/xxxx/xxx.txt */\n  private fileRawLink: string;\n  /** レポジトリ自体へのリンク。 https://gist.github.com/xxxxx/xxxx */\n  private repoLink: string;\n  /** gistのID。16進数のハッシュ値 */\n  private gistId: string;\n  private textValue: string;\n  constructor(private readonly element: HTMLDivElement) {\n    const footerData = this.getFooterData(element.querySelector(\".gist-meta\"));\n    this.fileName = footerData.fileName;\n    this.fileLink = footerData.fileLink;\n    this.fileRawLink = footerData.fileRawLink;\n    this.repoLink = footerData.repoLink;\n    this.gistId = footerData.gistId;\n    this.textValue = this.getInnerText(element.querySelector(\".gist-data\"));\n    const topBrotherElement = document.createElement(\"div\");\n    topBrotherElement.classList.add(\"header\");\n    topBrotherElement.innerHTML = `\n    <div class=\"filename\">hoge.txt</div>\n    <div class=\"space\"></div>\n    <a class=\"file-link\" href=\"http://example.com\">file</a>\n    <a class=\"raw-link\" href=\"http://example.com\">raw</a>\n    <a class=\"repo-link\" href=\"http://example.com\">repo</a>\n    <a class=\"edit-link\" href=\"http://example.com\">edit</a>\n    <button filename>filename</button>\n    <button text>text</button>\n    <button git-clone>git clone command</button>\n    <button download-zip-repo style=\"display:none;\">download zip repo</button>\n    `;\n    topBrotherElement.querySelector<HTMLElement>(\".filename\").innerText = this.fileName;\n    topBrotherElement.querySelector<HTMLAnchorElement>(\".file-link\").href = this.fileLink;\n    topBrotherElement.querySelector<HTMLAnchorElement>(\".raw-link\").href = this.fileRawLink;\n    topBrotherElement.querySelector<HTMLAnchorElement>(\".repo-link\").href = this.repoLink;\n    topBrotherElement.querySelector<HTMLAnchorElement>(\".edit-link\").href = this.repoLink + \"/edit\";\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[filename]\").setAttribute(\"title\", this.fileName);\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[filename]\").addEventListener(\"click\", () => { this.copyText(this.fileName); })\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[text]\").setAttribute(\"title\", this.textValue);\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[text]\").addEventListener(\"click\", () => { this.copyText(this.textValue); })\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[git-clone]\").setAttribute(\"title\", `git clone git@gist.github.com:${this.gistId}.git .`);\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[git-clone]\").addEventListener(\"click\", () => { this.copyText(`git clone git@gist.github.com:${this.gistId}.git .`); })\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[download-zip-repo]\").setAttribute(\"title\", `download zip file`);\n    topBrotherElement.querySelector<HTMLButtonElement>(\"[download-zip-repo]\").addEventListener(\"click\", () => { alert(\"wip\") })\n    element.insertBefore(topBrotherElement, element.children[0]);\n    // hide footer\n    element.querySelector<HTMLElement>(\".gist-meta\")!.style.display = \"none\";\n  }\n  private getInnerText(bodyElement: HTMLElement) {\n    return bodyElement.innerText.split(/\\n/).map(a => {\n      return a.replace(/^\\t/, \"\");\n    }).join(\"\\n\");\n  }\n  private copyText(text: string) {\n    navigator.clipboard.writeText(text);\n  }\n  /** 元のgistのfooterのエレメントから必要な情報を返す */\n  private getFooterData(footerElement: HTMLDivElement) {\n    const fileRawLink = footerElement.children[0].getAttribute(\"href\");\n    if (fileRawLink == null) { throw new Error(); }\n    let m: RegExpMatchArray;\n    if (!(m = fileRawLink.match(/(^.+?gist\\.github\\.com\\/.+?)\\/raw\\//))) {\n      throw new Error();\n    }\n    const repoLink = m[1];\n    if (!(m = repoLink.match(/(\\w+)$/))) {\n      throw new Error(\"gist hash id not found\");\n    }\n    const gistId = m[1];\n    const fileLink = (footerElement.children[1] as HTMLAnchorElement).href;\n    const fileName = (footerElement.children[1] as HTMLElement).innerText\n    return { fileRawLink, repoLink, gistId, fileName, fileLink };\n  }\n}\n","import { GistTools } from \"./gitsTool\";\n\ninit();\nfunction init() {\n  const elments = document.querySelectorAll(\".gist\");\n  for (let element of elments) {\n    if (element instanceof HTMLDivElement) {\n      GistTools.getInstance(element);\n    }\n  }\n}"],"sourceRoot":""}