ChatGPT Code Box Styling

Change the font size and enable word wrap in ChatGPT code boxes

// ==UserScript==
//人民的勤务员
// @name              ChatGPT Code Box Styling
// @description       Change the font size and enable word wrap in ChatGPT code boxes
// @name:zh-CN        ChatGPT代码字体缩小.
// @description:zh-CN ChatGPT 让代码字体变小 并且自动折行
// @name:ar           ChatGPT代码字体缩小
// @description:ar    ChatGPT جعل خط التعليمات البرمجية أصغر والتفاف تلقائيا
// @name:cs           ChatGPTVelikost písma kódu zmenšena
// @description:cs    ChatGPT Zmenšit písmo kódu a automaticky zabalit
// @name:da           ChatGPTKodeskriftstørrelse reduceret
// @description:da    ChatGPT Gør kodeskrifttypen mindre og automatisk indpakning
// @name:de           ChatGPTDie Schriftgröße des Codes wurde reduziert
// @description:de    ChatGPT Verkleinern Sie die Codeschrift und automatisch umwickeln
// @name:el           ChatGPTΜειώθηκε το μέγεθος γραμματοσειράς κώδικα
// @description:el    ChatGPT Κάντε τη γραμματοσειρά κώδικα μικρότερη και τυλίγεται αυτόματα
// @name:en           ChatGPTCode font size reduced
// @description:en    ChatGPT Make code font smaller and automatically wrap
// @name:eo           ChatGPTKoda tiparo grandeco reduktita
// @description:eo    ChatGPT Malgrandigu kodan tiparon kaj aŭtomate envolvi
// @name:es           ChatGPTTamaño de fuente del código reducido
// @description:es    ChatGPT Reducir la fuente del código y envolver automáticamente
// @name:fi           ChatGPTKoodin fonttikokoa pienennetty
// @description:fi    ChatGPT Pienennä koodin fonttia ja kääri automaattisesti
// @name:fr           ChatGPTTaille de la police du code réduite
// @description:fr    ChatGPT Rendre la police du code plus petite et envelopper automatiquement
// @name:he           ChatGPTגודל גופן הקוד מופחת
// @description:he    ChatGPT הקטן את גופן הקוד ועוטף אוטומטית
// @name:hr           ChatGPTSmanjena veličina fonta koda
// @description:hr    ChatGPT Smanjite font koda i automatski omotati
// @name:hu           ChatGPTA kód betűmérete csökkentve
// @description:hu    ChatGPT Csökkentse a kód betűtípusát és automatikusan becsomagolja
// @name:id           ChatGPTUkuran font kode dikurangi
// @description:id    ChatGPT Buat font kode lebih kecil dan secara otomatis membungkus
// @name:it           ChatGPTDimensione del carattere del codice ridotta
// @description:it    ChatGPT Rimpicciolisci il carattere del codice e avvolgi automaticamente
// @name:ja           ChatGPTコードのフォントサイズが小さくなりました
// @description:ja    ChatGPT コードのフォントを小さくする そして自动的に折り返す
// @name:ka           ChatGPTკოდის შრიფტის ზომა შემცირდა
// @description:ka    ChatGPT გაამცირეთ კოდის შრიფტი და ავტომატურად შეფუთვა
// @name:ko           ChatGPT코드 글꼴 크기 감소
// @description:ko    ChatGPT 코드 글꼴을 더 작게 만들기 자동으로 포장
// @name:nl           ChatGPTLettergrootte van code verkleind
// @description:nl    ChatGPT Maak het codelettertype kleiner en automatisch inpakken
// @name:nb           ChatGPTKodeskriftstørrelse redusert
// @description:nb    ChatGPT Gjør kodeskrift mindre og pakkes inn automatisk
// @name:pl           ChatGPTZmniejszono rozmiar czcionki kodu
// @description:pl    ChatGPT Zmniejsz czcionkę kodu i automatycznie zawijać
// @name:pt-BR        ChatGPTTamanho da fonte do código reduzido
// @description:pt-BR ChatGPT Diminuir a fonte do código e embrulhar automaticamente
// @name:ro           ChatGPTDimensiunea fontului codului a fost redusă
// @description:ro    ChatGPT Faceți fontul codului mai mic și înfășurați automat
// @name:ru           ChatGPTРазмер шрифта кода уменьшен
// @description:ru    ChatGPT Уменьшить шрифт кода и автоматически обернуть
// @name:sk           ChatGPTZmenšená veľkosť písma kódu
// @description:sk    ChatGPT Zmenšiť písmo kódu a automaticky zabaliť
// @name:sr           ChatGPTСмањена величина фонта кода
// @description:sr    ChatGPT Смањите фонт кода и аутоматски умотати
// @name:sv           ChatGPTKodens teckensnittsstorlek minskas
// @description:sv    ChatGPT Gör kodteckensnittet mindre och linda automatiskt
// @name:th           ChatGPTขนาดตัวอักษรโค้ดลดลง
// @description:th    ChatGPT ทำให้โค้ดฟอนต์เล็กลง และห่ออัตโนมัติ
// @name:tr           ChatGPTKod yazı tipi boyutu küçültüldü
// @description:tr    ChatGPT Kod yazı tipini küçültün ve otomatik olarak sar
// @name:ug           ChatGPTكود خەت چوڭلۇقى كىچىكلىتىلدى
// @description:ug    ChatGPT كود خەت نۇسخىسىنى كىچىكرەك قىلىڭ ھەمدە ئاپتوماتىك ئورايدۇ
// @name:uk           ChatGPTРозмір шрифту коду зменшено
// @description:uk    ChatGPT Зменшіть шрифт коду і автоматично обернути
// @name:vi           ChatGPTKích thước phông chữ mã giảm
// @description:vi    ChatGPT Làm cho phông chữ mã nhỏ hơn và tự động bọc
// @name:zh-TW        ChatGPT程序码字体缩小
// @description:zh-TW ChatGPT 让程序码字体变小 并且自动折行
// @name:zh-HK        ChatGPT程序码字体缩小
// @description:zh-HK ChatGPT 让程序码字体变小 并且自动折行
// @name:fr-CA        ChatGPTTaille de la police du code réduite
// @description:fr-CA ChatGPT Rendre la police du code plus petite et envelopper automatiquement

// @namespace         https://github.com/ChinaGodMan/UserScripts
// @version           0.1.1.0
// @author            人民的勤务员 <china.qinwuyuan@gmail.com>
// @match             https://chatgpt.com/*
// @grant             none
// @supportURL        https://github.com/ChinaGodMan/UserScripts/issues
// @homepageURL       https://github.com/ChinaGodMan/UserScripts
// @license           MIT
// @icon              
// ==/UserScript==
function addCustomCSS() {
    const css = `
        pre code {
            font-size: 12px !important; /* 设置字体大小为12px */
            white-space: pre-wrap !important; /* 设置自动换行 */
            word-break: break-word !important; /* 设置单词断行 */
        }
        pre {
            overflow-x: auto !important; /* 允许水平滚动 */
        }
    `

    function applyStyles() {
        let styleNode = document.createElement('style')
        styleNode.appendChild(document.createTextNode(css));
        (document.querySelector('head') || document.documentElement).appendChild(styleNode)
    }

    // 初次应用样式
    applyStyles()


    setInterval(() => {
        // 检查样式是否仍在<head>中
        const styles = document.querySelectorAll('style')
        const styleExists = Array.from(styles).some(style => style.textContent.includes(css))

        if (!styleExists) {
            applyStyles() // 如果样式不存在,则重新应用
        }
    }, 300)
}

// 调用函数以添加自定义CSS
addCustomCSS()