HF Group Image "OG"

Reduces group images

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Greasemonkey lub Violentmonkey.

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Violentmonkey.

Aby zainstalować ten skrypt, wymagana jest instalacje jednego z następujących rozszerzeń: Tampermonkey, Violentmonkey.

Aby zainstalować ten skrypt, wymagana będzie instalacja rozszerzenia Tampermonkey lub Userscripts.

You will need to install an extension such as Tampermonkey to install this script.

Aby zainstalować ten skrypt, musisz zainstalować rozszerzenie menedżera skryptów użytkownika.

(Mam już menedżera skryptów użytkownika, pozwól mi to zainstalować!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

Będziesz musiał zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

Będziesz musiał zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

Musisz zainstalować rozszerzenie menedżera stylów użytkownika, aby zainstalować ten styl.

(Mam już menedżera stylów użytkownika, pozwól mi to zainstalować!)

// ==UserScript==
// @name         HF Group Image "OG"
// @version      1.2
// @description  Reduces group images
// @author       gloom
// @match        https://hackforums.net/*
// @license      MIT
// @namespace http://tampermonkey.net/
// ==/UserScript==

(function() {
    'use strict';

    // Function to resize group images
    function resizeGroupImages() {
        // Find all images that have a src containing 'images/groupimages'
        const groupImages = document.querySelectorAll('img[src*="images/groupimages"]');

        groupImages.forEach(img => {
            // Get current dimensions from width/height attributes
            let currentWidth = parseInt(img.getAttribute('width'));
            let currentHeight = parseInt(img.getAttribute('height'));

            // Sets the new dimensions
            if (!isNaN(currentWidth) && !isNaN(currentHeight)) {
                const newWidth = currentWidth - 40;
                const newHeight = currentHeight - 15;

                img.setAttribute('width', newWidth);
                img.setAttribute('height', newHeight);
                // Also set style to ensure it takes effect
                img.style.width = newWidth + 'px';
                img.style.height = newHeight + 'px';
            }
        });
    }

    // Runs when page loads
    window.addEventListener('load', resizeGroupImages);

    // Run for dynamically loaded images
    const observer = new MutationObserver(resizeGroupImages);
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();