esa.io cpl

esa.ioのソースコードハイライト表示に機能追加

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         esa.io cpl
// @namespace    https://github.com/fushihara/esa-io-cpl
// @match        https://*.esa.io/posts/*
// @description  esa.ioのソースコードハイライト表示に機能追加
// @version      2.3.0
// @grant        none
// @license      MIT
// @source       https://github.com/fushihara/esa-io-cpl
// @homepage     https://greasyfork.org/ja/scripts/410892
// @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/esaCodeCopy.ts":
/*!****************************!*\
  !*** ./src/esaCodeCopy.ts ***!
  \****************************/
/*! exports provided: EsaCodeCopy */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EsaCodeCopy", function() { return EsaCodeCopy; });
const styleRuleInsertLog = new WeakMap();
const cssPrefix = `k777`;
class EsaCodeCopy {
    constructor(element) {
        this.element = element;
        const fileNameElement = element.querySelector(".code-filename");
        if (fileNameElement) {
            const fileName = element.querySelector(".code-filename").innerText;
            const insertElement = document.createElement("div");
            insertElement.classList.add(cssPrefix);
            insertElement.classList.add("code-block__copy-button");
            for (let v of getButtons(fileName)) {
                insertElement.appendChild(v.button);
            }
            element.querySelector(".highlight").appendChild(insertElement);
        }
        EsaCodeCopy.insertStyleRule();
    }
    static insertStyleRule() {
        if (styleRuleInsertLog.has(document)) {
            return;
        }
        styleRuleInsertLog.set(document, true);
        const styleEl = document.createElement("style");
        document.head.appendChild(styleEl);
        styleEl.sheet.insertRule(`.markdown .code-block__copy-button.${cssPrefix}{ position: absolute;top: -25px;right: 0;border:0;}`);
        styleEl.sheet.insertRule(`.markdown .code-block__copy-button.${cssPrefix} button{ font-family: monospace; font-size: 13px;line-height: 13px; }`);
        // デフォルトのコードハイライトの高さを変える
        styleEl.sheet.insertRule(`pre.highlight {line-height:13px;font-size:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace; }`);
    }
}
function copyText(str) {
    navigator.clipboard.writeText(str);
}
function getButtons(filePath) {
    const result = [];
    const splitPath = [...filePath.split(/[\\\/]/)];
    if (1 < splitPath.length) {
        const element = document.createElement("button");
        element.innerText = filePath;
        element.addEventListener("click", () => {
            copyText(filePath);
        });
        result.push({
            button: element,
            type: "all",
        });
    }
    for (let path of splitPath) {
        const element = document.createElement("button");
        element.innerText = path;
        element.addEventListener("click", () => {
            copyText(path);
        });
        result.push({
            button: element,
            type: "path",
        });
    }
    return result;
}


/***/ }),

/***/ "./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 _esaCodeCopy__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./esaCodeCopy */ "./src/esaCodeCopy.ts");

main();
function main() {
    const elements = document.querySelectorAll(".markdown > div.code-block");
    for (let e of elements) {
        new _esaCodeCopy__WEBPACK_IMPORTED_MODULE_0__["EsaCodeCopy"](e);
    }
}


/***/ })

/******/ });
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./src/esaCodeCopy.ts","webpack:///./src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAA,MAAM,kBAAkB,GAA+B,IAAI,OAAO,EAAE,CAAC;AACrE,MAAM,SAAS,GAAG,MAAM,CAAC;AAClB,MAAM,WAAW;IACtB,YAA6B,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;QAClD,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAc,gBAAgB,CAAC,CAAC;QAC7E,IAAI,eAAe,EAAE;YACnB,MAAM,QAAQ,GAAG,OAAO,CAAC,aAAa,CAAc,gBAAgB,CAAC,CAAC,SAAS,CAAC;YAChF,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACpD,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACvC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;YACvD,KAAK,IAAI,CAAC,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAClC,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;aACrC;YACD,OAAO,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;SAChE;QACD,WAAW,CAAC,eAAe,EAAE,CAAC;IAChC,CAAC;IACO,MAAM,CAAC,eAAe;QAC5B,IAAI,kBAAkB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACpC,OAAO;SACR;QACD,kBAAkB,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAChD,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACnC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,sCAAsC,SAAS,qDAAqD,CAAC,CAAC;QAC/H,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,sCAAsC,SAAS,uEAAuE,CAAC,CAAC;QACjJ,wBAAwB;QACxB,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,uHAAuH,CAAC,CAAC;IACpJ,CAAC;CACF;AACD,SAAS,QAAQ,CAAC,GAAW;IAC3B,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;AACrC,CAAC;AAED,SAAS,UAAU,CAAC,QAAgB;IAClC,MAAM,MAAM,GAAiB,EAAE,CAAC;IAChC,MAAM,SAAS,GAAG,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChD,IAAI,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE;QACxB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACjD,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC7B,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YACrC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC;YACV,MAAM,EAAE,OAAO;YACf,IAAI,EAAE,KAAK;SACZ,CAAC,CAAC;KACJ;IACD,KAAK,IAAI,IAAI,IAAI,SAAS,EAAE;QAC1B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACjD,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;QACzB,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YACrC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACjB,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC;YACV,MAAM,EAAE,OAAO;YACf,IAAI,EAAE,MAAM;SACb,CAAC,CAAC;KACJ;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;;;;;;;;;;;;;AC5DD;AAAA;AAA4C;AAE5C,IAAI,EAAE,CAAC;AACP,SAAS,IAAI;IACX,MAAM,QAAQ,GAAG,QAAQ,CAAC,gBAAgB,CAAiB,4BAA4B,CAAC,CAAC;IACzF,KAAK,IAAI,CAAC,IAAI,QAAQ,EAAE;QACtB,IAAI,wDAAW,CAAC,CAAC,CAAC,CAAC;KACpB;AACH,CAAC","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();\nconst cssPrefix = `k777`;\nexport class EsaCodeCopy {\n  constructor(private readonly element: HTMLDivElement) {\n    const fileNameElement = element.querySelector<HTMLElement>(\".code-filename\");\n    if (fileNameElement) {\n      const fileName = element.querySelector<HTMLElement>(\".code-filename\").innerText;\n      const insertElement = document.createElement(\"div\");\n      insertElement.classList.add(cssPrefix);\n      insertElement.classList.add(\"code-block__copy-button\");\n      for (let v of getButtons(fileName)) {\n        insertElement.appendChild(v.button);\n      }\n      element.querySelector(\".highlight\").appendChild(insertElement);\n    }\n    EsaCodeCopy.insertStyleRule();\n  }\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(`.markdown .code-block__copy-button.${cssPrefix}{ position: absolute;top: -25px;right: 0;border:0;}`);\n    styleEl.sheet.insertRule(`.markdown .code-block__copy-button.${cssPrefix} button{ font-family: monospace; font-size: 13px;line-height: 13px; }`);\n    // デフォルトのコードハイライトの高さを変える\n    styleEl.sheet.insertRule(`pre.highlight {line-height:13px;font-size:12px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace; }`);\n  }\n}\nfunction copyText(str: string) {\n  navigator.clipboard.writeText(str);\n}\ntype ButtonType = {button: HTMLButtonElement; type: \"all\" | \"path\"};\nfunction getButtons(filePath: string): ButtonType[] {\n  const result: ButtonType[] = [];\n  const splitPath = [...filePath.split(/[\\\\\\/]/)];\n  if (1 < splitPath.length) {\n    const element = document.createElement(\"button\");\n    element.innerText = filePath;\n    element.addEventListener(\"click\", () => {\n      copyText(filePath);\n    });\n    result.push({\n      button: element,\n      type: \"all\",\n    });\n  }\n  for (let path of splitPath) {\n    const element = document.createElement(\"button\");\n    element.innerText = path;\n    element.addEventListener(\"click\", () => {\n      copyText(path);\n    });\n    result.push({\n      button: element,\n      type: \"path\",\n    });\n  }\n  return result;\n}\n","import { EsaCodeCopy } from \"./esaCodeCopy\";\n\nmain();\nfunction main() {\n  const elements = document.querySelectorAll<HTMLDivElement>(\".markdown > div.code-block\");\n  for (let e of elements) {\n    new EsaCodeCopy(e);\n  }\n}"],"sourceRoot":""}