Like Automator

This is a "like" automator (first N posts only).

当前为 2024-10-07 提交的版本,查看 最新版本

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Like Automator
// @namespace    http://tampermonkey.net/
// @version      2.6
// @description  This is a "like" automator (first N posts only).
// @author       biganthonymo
// @match        https://x.com/*/status/*
// @icon              
// @grant        none
// @license MIT

// ==/UserScript==

(function() {
    'use strict';

    // Function to get random delay
    function getRandomDelay() {
        return Math.floor(Math.random() * 400) + 100; // Random delay between 100 and 500 ms
    }

    function simulatePageDown() {
        // Scroll down by the height of the viewport
        window.scrollBy(0, window.innerHeight);
    }

    function scrollDownMultipleTimes(times, delay) {
        for (let i = 0; i < times; i++) {
            setTimeout(function() {
                simulatePageDown();
            }, i * delay);
        }
    }

    function simulatePageUp() {
        // Scroll up by the height of the viewport
        window.scrollBy(0, -window.innerHeight);
    }

    function scrollUpMultipleTimes(times, delay) {
        for (let i = 0; i < times; i++) {
            setTimeout(function() {
                simulatePageUp();
            }, i * delay);
        }
    }

    // Create the floating button
    const floatButton = document.createElement('button');
    floatButton.innerText = 'Like Automator';
    Object.assign(floatButton.style, {
        position: 'fixed',
        bottom: '20px',
        left: '20px',
        zIndex: '9999',
        padding: '10px',
        backgroundColor: '#007bff',
        color: '#fff',
        border: 'none',
        borderRadius: '5px',
        cursor: 'pointer'
    });

    document.body.appendChild(floatButton);

    floatButton.addEventListener('click', function() {
        const buttons = document.querySelectorAll('[data-testid="like"]');
        let clickedCount = 0;
        //scrollDownMultipleTimes(8, 500); //Scrool down a few times to load more elements
        //scrollUpMultipleTimes(8, 100);

        function processButton(i) {
            if (i >= buttons.length || i >= 50) {
                return; // Stop if we've reached the end
            }

            // Scroll to the button so it becomes visible
            buttons[i].scrollIntoView({
                behavior: 'smooth',
                block: 'center'
            });

            // After scrolling, wait a bit before clicking
            setTimeout(function() {
                buttons[i].click();
                clickedCount++;

                // Update the floating button's text to show how many clicks have happened so far
                floatButton.innerText = `Like Automator (${clickedCount} / ${buttons.length - 1})`; //The 1st does not count

                // Process the next button after a random delay
                setTimeout(function() {
                    processButton(i + 1);
                }, getRandomDelay());
            }, 500); // Wait 500ms after scrolling before clicking
        }

        processButton(1); // Starting from 1 (the 2nd)
    });
})();