GitHub Gist Link

Adds a Gist link to GitHub profile pages.

Verzia zo dňa 26.02.2025. Pozri najnovšiu verziu.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, Greasemonkey alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey alebo Userscripts.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie, ako napríklad Tampermonkey.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie správcu používateľských skriptov.

(Už mám správcu používateľských skriptov, nechajte ma ho nainštalovať!)

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

(Už mám správcu používateľských štýlov, nechajte ma ho nainštalovať!)

// ==UserScript==
// @name         GitHub Gist Link
// @description  Adds a Gist link to GitHub profile pages.
// @icon         https://github.githubassets.com/favicons/favicon-dark.svg
// @version      1.0
// @author       afkarxyz
// @namespace    https://github.com/afkarxyz/misc-scripts/
// @supportURL   https://github.com/afkarxyz/misc-scripts/issues
// @license      MIT
// @match        https://github.com/*
// @exclude      https://gist.github.com/*
// @grant        none
// @run-at       document-idle
// ==/UserScript==

(function() {
    'use strict';
    
    function isProfilePage() {
        return /^\/[^\/]+\/?$/.test(window.location.pathname);
    }
    
    function addGistLink() {
        if (!isProfilePage()) return;
        
        const usernameElement = document.querySelector('.p-nickname.vcard-username');
        
        if (usernameElement && !usernameElement.querySelector('.gist-link-userscript')) {
            const currentURL = window.location.pathname;
            const username = currentURL.split('/')[1];
            
            const linkContainer = document.createElement('span');
            linkContainer.className = 'gist-link-container';
            
            const gistLink = document.createElement('a');
            gistLink.href = `https://gist.github.com/${username}`;
            gistLink.textContent = 'Gist';
            gistLink.className = 'Link--secondary gist-link-userscript';
            gistLink.style.textDecoration = 'none';
            
            linkContainer.appendChild(gistLink);
            linkContainer.appendChild(document.createTextNode(' · '));
            
            usernameElement.insertBefore(linkContainer, usernameElement.firstChild);
        }
    }
    
    function observeForUsernameElement() {
        if (!isProfilePage()) return;
        
        const usernameObserver = new MutationObserver((mutations, observer) => {
            const usernameElement = document.querySelector('.p-nickname.vcard-username');
            if (usernameElement) {
                addGistLink();
                observer.disconnect();
            }
        });
        
        usernameObserver.observe(document.body, { 
            childList: true, 
            subtree: true 
        });
    }
    
    if (document.readyState === 'complete' || document.readyState === 'interactive') {
        addGistLink();
    } else {
        document.addEventListener('DOMContentLoaded', addGistLink);
    }
    
    let lastUrl = location.href;
    const urlChangeObserver = new MutationObserver(() => {
        const url = location.href;
        if (url !== lastUrl) {
            lastUrl = url;
            if (document.querySelector('.p-nickname.vcard-username')) {
                addGistLink();
            } else {
                observeForUsernameElement();
            }
        }
    });
    
    urlChangeObserver.observe(document, {
        subtree: true, 
        childList: true
    });
    
    window.addEventListener('popstate', function() {
        if (document.querySelector('.p-nickname.vcard-username')) {
            addGistLink();
        } else {
            observeForUsernameElement();
        }
    });
    
    observeForUsernameElement();
})();