Jira history diff

Highliht diff in Jira issue history.

2024-05-14 기준 버전입니다. 최신 버전을 확인하세요.

이 스크립트를 설치하려면 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 history diff
// @version      2024-05-14
// @description  Highliht diff in Jira issue history.
// @author       vctls
// @match        https://*.atlassian.net/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=atlassian.net
// @grant        none
// @require      https://cdn.jsdelivr.net/gh/google/diff-match-patch@62f2e689f498f9c92dbc588c58750addec9b1654/javascript/diff_match_patch_uncompressed.js
// @license      MIT
// @namespace https://greasyfork.org/users/299396
// ==/UserScript==

(function() {
    'use strict';

    const handleMessage = () => {
        document
            .querySelectorAll('[data-testid="issue-history.ui.history-items.generic-history-item.history-item"] > div:last-child > div:last-child')
            .forEach((element) => {
            if (element.innerText.length < 100) return;

            const left = element.querySelector("div:first-child");
            const right = element.querySelector("div:last-child");

            if (!left || !right) return;

            element.style.display = "block";
            const dmp = new diff_match_patch();
            const diff = dmp.diff_main(left.innerText, right.innerText);
            dmp.diff_cleanupSemantic(diff);

            element.innerHTML = dmp.diff_prettyHtml(diff);
        });
    };

    const delayedHandler = () => {
        setTimeout(() => handleMessage(), 10);
    };

    (new MutationObserver(delayedHandler)).observe(document, {childList: true, subtree: true});

})();