GitHub Issue Highlighter

A userscript that highlights the linked-to comment

2016-05-22 기준 버전입니다. 최신 버전을 확인하세요.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name          GitHub Issue Highlighter
// @version       1.0.0
// @description   A userscript that highlights the linked-to comment
// @license       https://creativecommons.org/licenses/by-sa/4.0/
// @namespace     http://github.com/Mottie
// @include       https://github.com/*
// @run-at        document-idle
// @grant         GM_addStyle
// @author        Rob Garrison
// ==/UserScript==
/* global GM_addStyle */
/*jshint unused:true */
(function() {
  "use strict";

  GM_addStyle([
    // !important needed to override styles added by
    // https://github.com/StylishThemes/GitHub-Dark
    ".timeline-comment.selected { border-color: #4183C4 !important; }",
    ".timeline-comment.selected:before { border-right-color: #4183C4 !important; }"
  ].join(""));

  var init = function(event) {
    if (document.querySelector("#discussion_bucket")) {
      var target, indx,
        hash = window.location.hash;
      // remove "selected" class on hashchange
      if (event) {
        target = document.querySelectorAll(".timeline-comment");
        indx = target.length;
        while (indx--) {
          target[indx].classList.remove("selected");
        }
      }
      // add "selected" class
      if (/^#issue(comment)?-\d+/.test(hash)) {
        target = document.querySelector(hash);
        if (target) {
          target.classList.add("selected");
        }
      }
    }
  };

  window.addEventListener("hashchange", init);
  init();

})();