Telegram Web K(A) Post Enlarger

Increases minimum width of messages/posts in Telegram Web K and Telegram Web A

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да инсталирате разширение, като например Tampermonkey .

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

// ==UserScript==
// @name         Telegram Web K(A) Post Enlarger
// @namespace    https://violentmonkey.github.io/
// @version      1.0
// @description  Increases minimum width of messages/posts in Telegram Web K and Telegram Web A
// @author       Streampunk
// @icon         
// @match        https://web.telegram.org/k/*
// @match        https://web.telegram.org/a/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Function to inject or update custom styles
    function applyStyles() {
        // Remove previous style if exists
        const oldStyle = document.getElementById('tg-width-enlarger');
        if (oldStyle) {
            oldStyle.remove();
        }

        // Create new style element
        const style = document.createElement('style');
        style.id = 'tg-width-enlarger';
        style.textContent = `
            /* Main chat container */
            #RightColumn .messages-layout {
                min-width: 700px !important;
                max-width: none !important;
            }

            /* Message containers */
            .messages-layout .message,
            .message-bubble,
            .message-content,
            .bubble {
                min-width: 700px !important;
                width: auto !important;
                max-width: 100% !important;
                flex-shrink: 0 !important;
            }

            /* Inner content of messages */
            .message-inner,
            .text-content,
            .bubble-content,
            .webpage-message,
            .formatted-text {
                min-width: 650px !important;
                white-space: normal !important;
            }

            /* Channel posts and news items */
            .chat-list .message,
            .story-preview,
            .news-item,
            .channel-post {
                min-width: 700px !important;
            }

            /* Force minimum width on small screens */
            @media (max-width: 1300px) {
                #RightColumn {
                    min-width: 700px !important;
                }
                .middle-column {
                    min-width: 700px !important;
                }
            }
        `;
        document.head.appendChild(style);
    }

    // Apply styles immediately and on page load
    applyStyles();
    window.addEventListener('load', applyStyles);

    // Observe DOM changes for dynamically loaded messages
    const observer = new MutationObserver((mutations) => {
        let shouldUpdate = false;
        mutations.forEach((mutation) => {
            if (mutation.type === 'childList' && mutation.addedNodes.length > 0) {
                shouldUpdate = true;
            }
        });
        if (shouldUpdate) {
            applyStyles();
        }
    });

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

    // Reapply styles on window resize
    window.addEventListener('resize', applyStyles);

})();