Jira Image Linker

Add a hyperlink to image tags in Jira comments

이 스크립트를 설치하려면 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         Jira Image Linker
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  Add a hyperlink to image tags in Jira comments
// @author       Zetaphor
// @match        https://jira.ipgaxis.com/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    let interval = null;

    function wrapImagesInLinks() {
        const imageWraps = document.querySelectorAll('.image-wrap');

        imageWraps.forEach(imageWrap => {
            const imageTag = imageWrap.querySelector('img');

            if (imageTag) {
                const imageSource = imageTag.getAttribute('src');
                const imageLink = document.createElement('a');
                imageLink.href = imageSource;
                imageLink.target = '_blank';

                imageWrap.replaceChild(imageLink, imageTag);
                imageLink.appendChild(imageTag);
            }
        });
    }

    function observeDOM() {
        const targetNode = document.querySelector('.activity-comment');

        if (targetNode) {
            clearInterval(interval);
            wrapImagesInLinks();
        } else {
            setTimeout(observeDOM, 1000);
        }
    }

    interval = setInterval(observeDOM, 1000);
})();