DTF & VC Comments Expander

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

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==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();
})();