ValueEdge: Show images in original size

Images in descriptions cannot be viewed in original size. This script adds an overlay that does exactly that.

// ==UserScript==
// @name         ValueEdge: Show images in original size
// @namespace    https://github.com/ahr-huber/monkey-scripts/
// @version      2025-03-28
// @description  Images in descriptions cannot be viewed in original size. This script adds an overlay that does exactly that.
// @license      MIT
// @author       Andreas Huber
// @match        https://*.saas.microfocus.com/*
// @icon         
// @grant        none
// @sandbox      DOM
// ==/UserScript==

(function() {
    'use strict';

   function imageEnlarge() {
        const style = document.createElement("style");
        style.textContent = `
            .largeImgContainer {
                background-color: #000000db;
                display: flex;
                align-items: center;
                justify-content: center;
                position: fixed;
                top: 0;
                left: 0;
                width: 100vw;
                height: 100vh;
                overflow: scroll;

                img {
                 max-width: 98vw;/**/
                 max-height: 98vh;/**/
                }
                button.close{
                   position:fixed;
                   top:0;
                   right:3em;
                   color: black;
                   font-weight: bold;
                   background: white;
                   border:none;
                   width: 2em;
                   height: 2em;
                   border-radius: 50%;

                }
            }
        `;
        document.body.appendChild(style);
        imageEnlargeInternal();
    }

    function imageEnlargeInternal(){
        const images = document.querySelectorAll(".fr-wrapper img");
        if(images.length == 0){
            window.setTimeout(()=>{imageEnlargeInternal()}, 500);
        }else{
            images.forEach(img => {
                console.log("enlarger for" , img);
                const btnEnlarge = document.createElement("button");
                btnEnlarge.textContent = "⊕";

                img.addEventListener("click", (e) => {
                    e.preventDefault();
                    const largeImgContainer = document.createElement("div");
                    largeImgContainer.classList.add("largeImgContainer");

                    const largeImg = document.createElement("img");
                    largeImg.setAttribute("src", img.getAttribute("src"));
                    largeImgContainer.appendChild(largeImg);

                    const closeButton = document.createElement("button");
                    closeButton.textContent = "X";
                    closeButton.addEventListener("click", () => {largeImgContainer.remove()});
                    closeButton.classList.add("close");
                    largeImgContainer.appendChild(closeButton);

                    document.body.appendChild(largeImgContainer);
                });

            });
        }
    }

    imageEnlarge(); // add click handler to show images in original size
})();