Github tabs to Space

tabs to space

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

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

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==UserScript==
// @name Github tabs to Space
// @namespace github.com/alejandrosc/
// @match https://github.com/*
// @version 1.0.1
// @homepageURL https://github.com/alejandrosc
// @description tabs to space
// @grant none
// @run-at document-start
// ==/UserScript==

"use strict";

window.onload = function () {
  const spaces = 2;
  const regex_find = /^\t+/;
  const regex_split = /[^\t]/;

  const query_selector =
    ".highlight.tab-size.js-file-line-container td.blob-code.blob-code-inner.js-file-line";

  const elements = document.querySelectorAll(query_selector);

  for (let i = 0, length = elements.length; i < length; i++) {
    let line = elements[i];
    line.innerHTML = line.innerHTML.replace(
      regex_find,
      " ".repeat(spaces * line.innerHTML.split(regex_split)[0].length),
      line.innerHTML
    );
  }
};