ChatGPT Enhanced Customizer

Customize ChatGPT with advanced background, UI styling, text controls, and presets

As of 2024-08-22. See the latest version.

// ==UserScript==
// @name         ChatGPT Enhanced Customizer
// @namespace    https://github.com/elixirsneededx/ChatGPT-Enhanced-Customizer-TamperMonkey-
// @version      2.5
// @description  Customize ChatGPT with advanced background, UI styling, text controls, and presets
// @license      MIT
// @copyright    2024, elixirsneededx (https://github.com/elixirsneededx) @elixirsneededx on discord.
// @icon         
// @author       @elixirsneededx on discord
// @match        http*://chat.openai.com/*
// @match        http*://chatgpt.com/*
// @connect      greatest.deepsurf.us
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    const panel = document.createElement('div');
    panel.style.position = 'fixed';
    panel.style.top = '10px';
    panel.style.right = '10px';
    panel.style.padding = '15px';
    panel.style.backgroundColor = 'rgba(0, 0, 0, 0.85)';
    panel.style.borderRadius = '12px';
    panel.style.color = 'white';
    panel.style.zIndex = '9999';
    panel.style.fontFamily = 'Arial, sans-serif';
    panel.style.width = '300px';
    panel.style.boxShadow = '0 4px 12px rgba(0, 0, 0, 0.3)';

    const closeButton = document.createElement('button');
    closeButton.textContent = 'X';
    closeButton.style.position = 'absolute';
    closeButton.style.top = '5px';
    closeButton.style.right = '10px';
    closeButton.style.backgroundColor = 'transparent';
    closeButton.style.border = 'none';
    closeButton.style.color = 'white';
    closeButton.style.fontSize = '16px';
    closeButton.style.cursor = 'pointer';
    closeButton.addEventListener('click', () => {
        panel.style.display = 'none';
        reopenButton.style.display = 'block';
    });
    panel.appendChild(closeButton);

    const title = document.createElement('h3');
    title.textContent = 'ChatGPT Enhanced Customizer';
    title.style.marginBottom = '15px';
    title.style.textAlign = 'center';
    title.style.fontSize = '18px';
    title.style.color = '#ff00ff';
    panel.appendChild(title);

    const UITextColorLabel = document.createElement('label');
    UITextColorLabel.textContent = 'UI Text Color:';
    UITextColorLabel.style.display = 'block';
    UITextColorLabel.style.marginTop = '10px';
    panel.appendChild(UITextColorLabel);

    const UITextColorInput = document.createElement('input');
    UITextColorInput.type = 'color';
    UITextColorInput.value = '#ffffff';
    panel.appendChild(UITextColorInput);

    const backgroundColorLabel = document.createElement('label');
    backgroundColorLabel.textContent = 'Background Color:';
    backgroundColorLabel.style.display = 'block';
    backgroundColorLabel.style.marginTop = '10px';
    panel.appendChild(backgroundColorLabel);

    const backgroundColorInput = document.createElement('input');
    backgroundColorInput.type = 'color';
    backgroundColorInput.value = '#000000';
    panel.appendChild(backgroundColorInput);

    const fontLabel = document.createElement('label');
    fontLabel.textContent = 'Font:';
    fontLabel.style.display = 'block';
    fontLabel.style.marginTop = '10px';
    panel.appendChild(fontLabel);

    const fontSelect = document.createElement('select');
    fontSelect.style.backgroundColor = 'black';
    fontSelect.style.color = 'white';
    fontSelect.style.border = '1px solid #ffffff';
    fontSelect.style.padding = '5px';
    fontSelect.style.width = '100%';
    fontSelect.style.borderRadius = '4px';
    fontSelect.style.fontFamily = 'Arial, sans-serif';

    const fonts = ['Arial', 'Comic Sans MS', 'Courier New', 'Georgia', 'Times New Roman', 'Verdana', 'Algerian'];
    fonts.forEach((font) => {
        const option = document.createElement('option');
        option.value = font;
        option.textContent = font;
        option.style.fontFamily = font;
        fontSelect.appendChild(option);
    });
    panel.appendChild(fontSelect);

    const chatFontSizeLabel = document.createElement('label');
    chatFontSizeLabel.textContent = 'Chat Font Size:';
    chatFontSizeLabel.style.display = 'block';
    chatFontSizeLabel.style.marginTop = '10px';
    panel.appendChild(chatFontSizeLabel);

    const chatFontSizeInput = document.createElement('input');
    chatFontSizeInput.type = 'range';
    chatFontSizeInput.min = '10';
    chatFontSizeInput.max = '36';
    chatFontSizeInput.value = '16';
    chatFontSizeInput.style.width = '100%';
    panel.appendChild(chatFontSizeInput);

    const applyButton = document.createElement('button');
    applyButton.textContent = 'Apply';
    applyButton.style.display = 'block';
    applyButton.style.marginTop = '15px';
    applyButton.style.width = '100%';
    applyButton.style.backgroundColor = '#ff00ff';
    applyButton.style.color = 'white';
    applyButton.style.padding = '10px';
    applyButton.style.border = 'none';
    applyButton.style.cursor = 'pointer';
    applyButton.style.fontSize = '16px';
    applyButton.style.borderRadius = '4px';
    applyButton.addEventListener('click', () => {
        document.body.style.backgroundColor = backgroundColorInput.value;
        document.body.style.color = UITextColorInput.value;
        document.body.style.fontFamily = fontSelect.value;
        document.querySelector('.chat-box').style.fontSize = chatFontSizeInput.value + 'px';
    });
    panel.appendChild(applyButton);

    const presetsLabel = document.createElement('label');
    presetsLabel.textContent = 'Presets:';
    presetsLabel.style.display = 'block';
    presetsLabel.style.marginTop = '10px';
    panel.appendChild(presetsLabel);

    const presetsSelect = document.createElement('select');
    presetsSelect.style.width = '100%';
    presetsSelect.style.padding = '5px';
    presetsSelect.style.marginTop = '5px';

    const presetOptions = [
        { name: 'Anime', bg: 'url(https://github.com/elixirsneededx/ChatGPT-Enhanced-Customizer-TamperMonkey-/blob/main/anime-preset.jpg)', color: '#ff00ff', font: 'Algerian' },
        { name: 'Slinky Style', bg: 'url(https://github.com/elixirsneededx/ChatGPT-Enhanced-Customizer-TamperMonkey-/blob/main/Slinky.gif)', color: '#00ffff', font: 'Comic Sans MS' },
        { name: 'Bluematrix Style', bg: 'url(https://github.com/elixirsneededx/ChatGPT-Enhanced-Customizer-TamperMonkey-/blob/main/Bluematrix.gif)', color: '#0000ff', font: 'Times New Roman' }
    ];

    presetOptions.forEach((preset) => {
        const option = document.createElement('option');
        option.value = preset.name;
        option.textContent = preset.name;
        presetsSelect.appendChild(option);
    });

    panel.appendChild(presetsSelect);

    presetsSelect.addEventListener('change', () => {
        const selectedPreset = presetOptions.find(preset => preset.name === presetsSelect.value);
        if (selectedPreset) {
            document.body.style.backgroundImage = selectedPreset.bg;
            document.body.style.color = selectedPreset.color;
            document.body.style.fontFamily = selectedPreset.font;
        }
    });

    const advancedSettings = document.createElement('h4');
    advancedSettings.textContent = 'UI Options';
    advancedSettings.style.marginTop = '15px';
    advancedSettings.style.color = '#ff00ff';
    panel.appendChild(advancedSettings);

    const transparencyLabel = document.createElement('label');
    transparencyLabel.textContent = 'UI Transparency:';
    transparencyLabel.style.display = 'block';
    transparencyLabel.style.marginTop = '5px';
    panel.appendChild(transparencyLabel);

    const transparencyInput = document.createElement('input');
    transparencyInput.type = 'range';
    transparencyInput.min = '0';
    transparencyInput.max = '100';
    transparencyInput.value = '85';
    transparencyInput.style.width = '100%';
    panel.appendChild(transparencyInput);

    transparencyInput.addEventListener('input', () => {
        panel.style.backgroundColor = `rgba(0, 0, 0, ${transparencyInput.value / 100})`;
    });

    const shapeLabel = document.createElement('label');
    shapeLabel.textContent = 'UI Shape:';
    shapeLabel.style.display = 'block';
    shapeLabel.style.marginTop = '5px';
    panel.appendChild(shapeLabel);

    const shapeSelect = document.createElement('select');
    shapeSelect.style.width = '100%';
    shapeSelect.style.padding = '5px';

    const shapeOptions = ['Square', 'Rounded', 'Circular'];
    shapeOptions.forEach((shape) => {
        const option = document.createElement('option');
        option.value = shape;
        option.textContent = shape;
        shapeSelect.appendChild(option);
    });

    panel.appendChild(shapeSelect);

    shapeSelect.addEventListener('change', () => {
        if (shapeSelect.value === 'Square') {
            panel.style.borderRadius = '0px';
        } else if (shapeSelect.value === 'Rounded') {
            panel.style.borderRadius = '12px';
        } else if (shapeSelect.value === 'Circular') {
            panel.style.borderRadius = '50%';
        }
    });

    const languageLabel = document.createElement('label');
    languageLabel.textContent = 'Localization:';
    languageLabel.style.display = 'block';
    languageLabel.style.marginTop = '5px';
    panel.appendChild(languageLabel);

    const languageSelect = document.createElement('select');
    languageSelect.style.width = '100%';
    languageSelect.style.padding = '5px';

    const languageOptions = ['English', 'Spanish', 'French', 'German', 'Japanese'];
    languageOptions.forEach((lang) => {
        const option = document.createElement('option');
        option.value = lang;
        option.textContent = lang;
        languageSelect.appendChild(option);
    });

    panel.appendChild(languageSelect);

    languageSelect.addEventListener('change', () => {
        if (languageSelect.value === 'Spanish') {
            title.textContent = 'Personalizador Mejorado de ChatGPT';
            applyButton.textContent = 'Aplicar';
            closeButton.textContent = 'Cerrar';
            presetsLabel.textContent = 'Preajustes:';
        } else if (languageSelect.value === 'French') {
            title.textContent = 'Personnalisateur Amélioré ChatGPT';
            applyButton.textContent = 'Appliquer';
            closeButton.textContent = 'Fermer';
            presetsLabel.textContent = 'Préréglages:';
        } else if (languageSelect.value === 'German') {
            title.textContent = 'Erweiterter ChatGPT-Anpasser';
            applyButton.textContent = 'Anwenden';
            closeButton.textContent = 'Schließen';
            presetsLabel.textContent = 'Voreinstellungen:';
        } else if (languageSelect.value === 'Japanese') {
            title.textContent = 'ChatGPTカスタマイザー';
            applyButton.textContent = '適用';
            closeButton.textContent = '閉じる';
            presetsLabel.textContent = 'プリセット:';
        } else {
            title.textContent = 'ChatGPT Enhanced Customizer';
            applyButton.textContent = 'Apply';
            closeButton.textContent = 'X';
            presetsLabel.textContent = 'Presets:';
        }
    });

    const backupButton = document.createElement('button');
    backupButton.textContent = 'Backup Settings';
    backupButton.style.display = 'block';
    backupButton.style.marginTop = '10px';
    backupButton.style.width = '100%';
    backupButton.style.backgroundColor = '#ff00ff';
    backupButton.style.color = 'white';
    backupButton.style.padding = '10px';
    backupButton.style.border = 'none';
    backupButton.style.cursor = 'pointer';
    backupButton.style.fontSize = '16px';
    backupButton.style.borderRadius = '4px';
    backupButton.addEventListener('click', () => {
        const settings = {
            UITextColor: UITextColorInput.value,
            backgroundColor: backgroundColorInput.value,
            font: fontSelect.value,
            chatFontSize: chatFontSizeInput.value,
            transparency: transparencyInput.value,
            shape: shapeSelect.value,
            language: languageSelect.value
        };
        localStorage.setItem('chatgpt-enhanced-settings', JSON.stringify(settings));
        alert('Settings have been backed up.');
    });
    panel.appendChild(backupButton);

    const resetButton = document.createElement('button');
    resetButton.textContent = 'Reset to Default';
    resetButton.style.display = 'block';
    resetButton.style.marginTop = '10px';
    resetButton.style.width = '100%';
    resetButton.style.backgroundColor = '#ff00ff';
    resetButton.style.color = 'white';
    resetButton.style.padding = '10px';
    resetButton.style.border = 'none';
    resetButton.style.cursor = 'pointer';
    resetButton.style.fontSize = '16px';
    resetButton.style.borderRadius = '4px';
    resetButton.addEventListener('click', () => {
        localStorage.removeItem('chatgpt-enhanced-settings');
        location.reload();
    });
    panel.appendChild(resetButton);

    const savedSettings = localStorage.getItem('chatgpt-enhanced-settings');
    if (savedSettings) {
        const settings = JSON.parse(savedSettings);
        UITextColorInput.value = settings.UITextColor;
        backgroundColorInput.value = settings.backgroundColor;
        fontSelect.value = settings.font;
        chatFontSizeInput.value = settings.chatFontSize;
        transparencyInput.value = settings.transparency;
        shapeSelect.value = settings.shape;
        languageSelect.value = settings.language;
        applyButton.click();
    }
})();