GitHub Notification Right Click to Repo Page

Open the repository home page with a right click on the notification item. 右键点击 GitHub 的通知项直接跳转到项目主页。

이 스크립트를 설치하려면 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 Notification Right Click to Repo Page
// @namespace    http://clear.studio/
// @version      0.3
// @license MIT
// @description  Open the repository home page with a right click on the notification item. 右键点击 GitHub 的通知项直接跳转到项目主页。
// @author       Kytrun
// @match        https://github.com/notifications*
// @icon         https://github.com/favicon.ico
// @grant        none
// ==/UserScript==

(function () {
    'use strict';
    const rightClickOpenRepo = () => {
        const lis = document.querySelectorAll('li.notifications-list-item');
        lis.forEach(li => {
            if(!li.dataset.directlyHome){
                const notifiLink = li.querySelector('a.notification-list-item-link').href;
                const repoReg = /(https:\/\/github\.com\/[a-zA-Z0-9-]+\/[a-zA-Z0-9-\.]+)\/.+/;
                const repoLink = notifiLink.replace(repoReg, '$1');
                //console.log(repoLink);
                li.addEventListener('contextmenu', function (ev) {
                    ev.preventDefault();
                    window.open(repoLink);
                    return false;
                }, false);
                li.dataset.directlyHome = "true"
                //li.style.color = 'red'
            }
        });
    }

    //rightClickOpenRepo();

    const observe = ()=>{
        const callback = function (mutationsList, observer) {
            rightClickOpenRepo();
        };
        const observer = new MutationObserver(callback);
        const observedNode = document.body;
        const config = { attributes: true, childList: true,subtree: true };
        observer.observe(observedNode, config);
        //observer.disconnect();
    }
    observe();
})();