DTF & VC Comments Expander

Automatically expands all subcomments on dtf.ru & vc.ru after manually clicking the "Show all comments" button.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         DTF & VC Comments Expander
// @namespace    https://tampermonkey.net/
// @version      2.0
// @description  Automatically expands all subcomments on dtf.ru & vc.ru after manually clicking the "Show all comments" button.
// @author       Streampunk
// @icon         
// @match        https://dtf.ru/*
// @match        https://vc.ru/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Function to find and monitor the main "Show all comments" button
    function findMainButton() {
        // Try multiple selectors for the main button
        const mainButtonSelector = 'button[data-gtm-click*="Show All Comments"], .comments-limit--bottom > button, .comments-limit button';
        let mainButton = document.querySelector(mainButtonSelector);

        if (mainButton) {
            console.log('Main comments button found.');
            attachMainButtonListener(mainButton);
            return;
        }

        // If not found, observe DOM for changes
        console.log('Main comments button not found initially. Observing DOM...');
        const observer = new MutationObserver(() => {
            mainButton = document.querySelector(mainButtonSelector);
            if (mainButton) {
                console.log('Main comments button found via observer.');
                attachMainButtonListener(mainButton);
                observer.disconnect(); // Stop observing once found
            }
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true
        });

        // Timeout to stop observing after 10 seconds if button is not found
        setTimeout(() => {
            if (!mainButton) {
                console.log('Main comments button not found after observing.');
                observer.disconnect();
            }
        }, 10000);
    }

    // Attach click event listener to the main button
    function attachMainButtonListener(mainButton) {
        mainButton.addEventListener('click', function() {
            console.log('Main comments button clicked. Starting subcomment expansion...');
            setTimeout(startExpanding, 2000); // Delay to ensure comments load
        });
    }

    // Function to repeatedly find and click expand buttons for subcomments
    function startExpanding() {
        const interval = setInterval(function() {
            // Select all expand buttons, including those with data-branch-semi-expandable and comments-limit__expand
            const expandButtons = document.querySelectorAll(
                '.comments-tree .comment__expand[data-gtm-click*="Comment — Open Thread"], ' +
                '.comments-tree .comment__expand[data-branch-semi-expandable="true"], ' +
                '.comments-limit__expand'
            );

            let clickedAny = false;

            expandButtons.forEach(btn => {
                // Check if the button is for expanding (contains "ответ", "ответа", "ответов", or "комментария")
                const buttonText = btn.textContent.trim().toLowerCase();
                if (
                    buttonText.includes('ответ') ||
                    buttonText.includes('ответа') ||
                    buttonText.includes('ответов') ||
                    buttonText.includes('комментарий') ||
                    buttonText.includes('комментария') ||
                    buttonText.includes('комментариев')
                ) {
                    btn.click();
                    clickedAny = true;
                    console.log('Clicked expand button:', buttonText);
                }
            });

            // If no buttons were clicked, stop the interval
            if (!clickedAny) {
                clearInterval(interval);
                console.log('All subcomments expanded or no more expandable comments found.');
            }
        }, 1500); // Interval to allow DOM updates
    }

    // Start the process
    findMainButton();
})();