ValueEdge: Follow Tickets

Automatically follow tickets when you add comments or click the save button

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name         ValueEdge: Follow Tickets
// @namespace    https://github.com/ahr-huber/monkey-scripts/
// @version      2025-11-04
// @description  Automatically follow tickets when you add comments or click the save button
// @license      MIT
// @author       Andreas Huber
// @match        https://*.saas.microfocus.com/*
// @match        https://ot-internal.saas.microfocus.com/ui/?p=4001/13012
// @icon         
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    function clickFollowIcon() {
        if (!isAlreadyFollowing()) // check again, because multiple clicks without page reload
        {
            document.querySelector("button[data-aid='alm-entity-form-header-follow']").click();
        }
    }

    function isFullyLoaded(){
        const alreadyFollowing = document.querySelector("[data-aid='alm-entity-form-header-following']");
        const notYetFollowing = document.querySelector("button[data-aid='alm-entity-form-header-follow']");
        return alreadyFollowing != null || notYetFollowing != null;
    }

    function isAlreadyFollowing(){
        const alreadyFollowing = document.querySelector("[data-aid='alm-entity-form-header-following']");
        return !!alreadyFollowing;
    }

    function addClickHandlerIfNotExists(selector, handler) {
        const element = document.querySelector(selector);
        if (element && element.getAttribute("data-tamper-click") == null) {
            element.addEventListener("click", handler);
            element.setAttribute("data-tamper-click", "true");
            //element.style.outline="1px dotted red";
        }
    }

    function ensureClickHandler(selector, handler){
        window.setInterval(()=>{
            if (!isFullyLoaded() || isAlreadyFollowing()){
                return;
            }

            const selectors = [
                "button[icon='save']", // save button
                'button[data-aid="comments-pane-add-new-comment-button"]' // save a new comment
            ];
            selectors.forEach(it =>{
                addClickHandlerIfNotExists(it, () =>clickFollowIcon());
            });

        }, 1000);
    }

    ensureClickHandler();
})();