gist github look fix

gist.githubのembedの外見を修正

От 06.09.2020. Виж последната версия.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==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":""}