Code Block Wrapping Enhancer For ChatGPT

Replaces or adds the "!whitespace-pre-wrap" class to <code> elements.

K instalaci tototo skriptu si budete muset nainstalovat rozšíření jako Tampermonkey, Greasemonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Violentmonkey.

K instalaci tohoto skriptu si budete muset nainstalovat rozšíření jako Tampermonkey nebo Userscripts.

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

K instalaci tohoto skriptu si budete muset nainstalovat manažer uživatelských skriptů.

(Už mám manažer uživatelských skriptů, nechte mě ho nainstalovat!)

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.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(Už mám manažer uživatelských stylů, nechte mě ho nainstalovat!)

// ==UserScript==
// @name         Code Block Wrapping Enhancer For ChatGPT
// @namespace    http://tampermonkey.net/
// @version      1.3
// @description  Replaces or adds the "!whitespace-pre-wrap" class to <code> elements.
// @match        *://chatgpt.com/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // Function to process <code> elements
    function updateCodeClass() {
        document.querySelectorAll('code').forEach(code => {
            if (code.classList.contains('!whitespace-pre')) {
                // Replace "!whitespace-pre" with "!whitespace-pre-wrap"
                code.classList.replace('!whitespace-pre', '!whitespace-pre-wrap');
            } else {
                // Add "!whitespace-pre-wrap" if it doesn't exist
                code.classList.add('!whitespace-pre-wrap');
            }
        });
    }

    // Create a MutationObserver to handle dynamically added elements
    const observer = new MutationObserver(() => updateCodeClass());

    // Start observing the document for changes
    observer.observe(document.body, { childList: true, subtree: true });

    // Initial execution
    updateCodeClass();
})();