AddNewIssueButton

Adds an issue creation button to GitHub repository pages.

이 스크립트를 설치하려면 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         AddNewIssueButton
// @namespace    http://tampermonkey.net/
// @version      0.0.1
// @description  Adds an issue creation button to GitHub repository pages.
// @author       zcf0508
// @match        https://github.com/*/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=github.com
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    const repoData = window.location.pathname.split('/');
    const repoName = repoData[2];
    const userName = repoData[1];
    const repo = `${userName}/${repoName}`;

    const createButton = () => {
        const button = document.createElement('button');
        button.textContent = 'Add Issue';
        button.className = 'btn btn-primary';
        button.addEventListener('click', () => {
            location.href = `https://github.com/${repo}/issues/new`;
        });
        return button;
    };

    const appendButton = () => {
        if (repoName && userName) {
            let parent = document.querySelector('.AppHeader-actions');
            let issuesTab = document.querySelector('#issues-tab');
            if (parent && issuesTab) {
                parent.appendChild(createButton());
            }
        }
    };

    // Use MutationObserver to ensure the button is added when the DOM changes
    const observer = new MutationObserver((mutationsList, observer) => {
        for (let mutation of mutationsList) {
            if (mutation.type === 'childList') {
                appendButton();
                observer.disconnect(); // Disconnect after adding the button
                break;
            }
        }
    });

    observer.observe(document.body, { childList: true, subtree: true });

    // Fallback to DOMContentLoaded in case the DOM is already loaded
    document.addEventListener('DOMContentLoaded', appendButton);
})();