Telegram Background Changer

Replaces the default Telegram background with a custom solid color or wallpaper when not logged in

// ==UserScript==
// @name         Telegram Background Changer
// @namespace    https://violentmonkey.github.io/
// @version      1.0
// @description  Replaces the default Telegram background with a custom solid color or wallpaper when not logged in
// @author       Streampunk
// @icon         
// @match        https://t.me/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Configuration: Set to true for solid color, false for wallpaper background image
    const useCustomColor = true; // true = use solid color, false = use wallpaper background image

    // Define the custom background color (used if useCustomColor = true or as fallback)
    const customBackgroundColor = '#000000'; // Change to any HEX color, e.g., '#000000' for deep black
    //const customBackgroundColor = '#1a1a1a'; // dark gray
    //const customBackgroundColor = '#8AB985'; // sage green

    // Define the custom wallpaper background image URL (used if useCustomColor = false)
    const customBackgroundImage = 'https://images.pexels.com/photos/1042423/pexels-photo-1042423.jpeg'; // Replace with your image URL, e.g. Yellow Flowering Green Plants
    //const customBackgroundImage = 'https://images.pexels.com/photos/36487/above-adventure-aerial-air.jpg'; // Air Balloon hovering over Water during Night Time
    //const customBackgroundImage = 'https://images.pexels.com/photos/7919/pexels-photo.jpg'; // Cloudy Mountain

    // Optional: Improve text readability by setting text color and shadow
    const improveTextReadability = true; // Set to true to apply white text with shadow
    const textColor = '#ffffff'; // Text color for better readability
    const textShadow = '1px 1px 2px rgba(0, 0, 0, 0.8)'; // Shadow for text

    // Function to replace the background
    function replaceBackground() {
        // Check if the page is a Telegram page
        if (window.location.href.includes('t.me')) {
            // Get the body and background wrapper elements
            const body = document.body;
            const backgroundWrap = document.querySelector('.tgme_background_wrap');
            const canvas = document.getElementById('tgme_background');
            const pattern = document.querySelector('.tgme_background_pattern');

            // Remove the canvas element to prevent the animated background
            if (canvas) {
                canvas.remove();
            }

            // Remove the pattern overlay if present
            if (pattern) {
                pattern.remove();
            }

            // Apply background (color or image)
            if (useCustomColor) {
                // Apply solid color
                body.style.background = customBackgroundColor;
                body.style.backgroundColor = customBackgroundColor;
                if (backgroundWrap) {
                    backgroundWrap.style.background = customBackgroundColor;
                    backgroundWrap.style.backgroundColor = customBackgroundColor;
                }
            } else {
                // Apply wallpaper background image
                body.style.background = `url('${customBackgroundImage}') no-repeat center center fixed`;
                body.style.backgroundSize = 'cover';
                if (backgroundWrap) {
                    backgroundWrap.style.background = `url('${customBackgroundImage}') no-repeat center center fixed`;
                    backgroundWrap.style.backgroundSize = 'cover';
                }
            }

            // Ensure the background covers the entire page
            body.style.minHeight = '100vh';
            if (backgroundWrap) {
                backgroundWrap.style.minHeight = '100vh';
            }

            // Improve text readability if enabled
            if (improveTextReadability) {
                const textElements = document.querySelectorAll(
                    '.tgme_page_title, .tgme_page_description, .tgme_page_extra, .tgme_page_additional, ' +
                    '.tgme_page_context_link, .tgme_page_widget_actions, .tgme_action_button_new, .tgme_action_button_label'
                );
                textElements.forEach(element => {
                    element.style.color = textColor;
                    element.style.textShadow = textShadow;
                });
            }

            // Attempt to disable TWallpaper animations
            if (window.TWallpaper) {
                window.TWallpaper.animate = function() {};
                window.TWallpaper.update = function() {};
            }
        }
    }

    // Execute the function when the page loads
    window.addEventListener('load', replaceBackground);

    // Observe DOM changes to handle dynamically loaded elements (e.g., widget)
    const observer = new MutationObserver(replaceBackground);
    observer.observe(document.body, { childList: true, subtree: true });

    // Override TWallpaper initialization to prevent default background
    Object.defineProperty(window, 'TWallpaper', {
        value: {
            init: function() {}, // Empty init function
            animate: function() {}, // Empty animate function
            update: function() {} // Empty update function
        },
        writable: false
    });

    // Handle widget loading by reapplying the background after a delay
    setTimeout(replaceBackground, 1000); // Reapply after 1 second to catch widget load
})();