Greasy Fork is available in English.

GitHub Inline Issue Link Bypass

Force normal navigation for GitHub issue and PR links that GitHub opens in preview modals.

2026-04-18 기준 버전입니다. 최신 버전을 확인하세요.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         GitHub Inline Issue Link Bypass
// @namespace    https://github.com/
// @version      0.1.0
// @description  Force normal navigation for GitHub issue and PR links that GitHub opens in preview modals.
// @author       alexchexes
// @icon         https://www.google.com/s2/favicons?sz=64&domain=github.com
// @match        https://github.com/*
// @run-at       document-start
// @grant        none
// @license      MIT
// @contributionURL https://ko-fi.com/alexchexes
// @contributionURL https://github.com/sponsors/alexchexes
// ==/UserScript==

(() => {
  'use strict';

  const allowedHovercardTypes = new Set(['issue', 'pull_request']);
  const issuePathPattern = /^\/[^/?#]+\/[^/?#]+\/(?:issues|pull)\/\d+$/;

  function getAnchorFromEvent(event) {
    if (typeof event.composedPath === 'function') {
      for (const node of event.composedPath()) {
        if (node instanceof HTMLAnchorElement && node.href) {
          return node;
        }
      }
    }

    if (!(event.target instanceof Node)) {
      return null;
    }

    const element =
      event.target.nodeType === Node.ELEMENT_NODE
        ? event.target
        : event.target.parentElement;

    return element?.closest?.('a[href]') ?? null;
  }

  function getForcedNavigationHref(event, anchor) {
    if (event.button !== 0) {
      return null;
    }

    if (event.metaKey || event.ctrlKey || event.shiftKey || event.altKey) {
      return null;
    }

    if (anchor.hasAttribute('download')) {
      return null;
    }

    if (anchor.target && anchor.target.toLowerCase() !== '_self') {
      return null;
    }

    if (!allowedHovercardTypes.has(anchor.dataset.hovercardType || '')) {
      return null;
    }

    const url = new URL(anchor.href, location.href);

    if (url.origin !== location.origin) {
      return null;
    }

    if (!issuePathPattern.test(url.pathname)) {
      return null;
    }

    return url.href;
  }

  window.addEventListener(
    'click',
    (event) => {
      const anchor = getAnchorFromEvent(event);

      if (!anchor) {
        return;
      }

      const href = getForcedNavigationHref(event, anchor);

      if (!href) {
        return;
      }

      event.preventDefault();
      event.stopImmediatePropagation();
      location.assign(href);
    },
    { capture: true, passive: false }
  );
})();