SteamDB Auto Activate

Автоматически активировать пакеты на сайте https://steamdb.info/freepackages/ и выводить отчет времени в консоли браузера.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         SteamDB Auto Activate
// @version      2.5
// @description  Автоматически активировать пакеты на сайте https://steamdb.info/freepackages/ и выводить отчет времени в консоли браузера.
// @match        https://steamdb.info/freepackages/*
// @namespace    Role_Play
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    var countdownInterval;

    function activatePackages() {
        clearInterval(countdownInterval);
        var activateButton = document.getElementById('js-activate-now');
        if (activateButton && activateButton.offsetParent !== null && !activateButton.classList.contains('btn-progress')) {
            activateButton.click();
        }
    }

    function hideDemosAndLegacyMedia() {
        var hideButton = document.getElementById('js-hide-demos');
        if (hideButton && hideButton.offsetParent !== null && !hideButton.classList.contains('btn-progress')) {
            hideButton.click();
            setTimeout(hideDemosAndLegacyMedia, 1000);
        }
    }

    function displayTimeReport() {
        var countdown = 30;
        var stopButton = document.createElement('button');
        stopButton.textContent = 'Stop';
        stopButton.style.position = 'fixed';
        stopButton.style.bottom = '10px';
        stopButton.style.right = '10px';
        stopButton.style.zIndex = '9999';
        stopButton.style.padding = '10px';
        stopButton.style.backgroundColor = '#3498db';
        stopButton.style.color = '#fff';
        stopButton.style.border = 'none';
        stopButton.style.cursor = 'pointer';
        document.body.appendChild(stopButton);

        function updateReport() {
            console.log('%c Активация продуктов через: ' + countdown + ' сек.', 'color: #c0392b; font-size: 18px; font-weight: bold;');
        }

        countdownInterval = setInterval(function() {
            countdown--;
            updateReport();

            if (countdown <= 0) {
                clearInterval(countdownInterval);
                updateReport();
                activatePackages();
                stopButton.style.display = 'none';
            }
        }, 1000);

        stopButton.addEventListener('click', function() {
            clearInterval(countdownInterval);
            console.log('%c Отчет времени остановлен.', 'color: #c0392b; font-size: 18px; font-weight: bold;');
            stopButton.style.display = 'none';
        });

        window.addEventListener('keydown', function(event) {
            if (event.key.toLowerCase() === 's' && event.ctrlKey && !event.altKey && !event.shiftKey) {
                clearInterval(countdownInterval);
                stopButton.style.display = 'none';
            }
        });
    }

    function delay(ms) {
        return new Promise(resolve => setTimeout(resolve, ms));
    }

    delay(2000).then(() => {
        hideDemosAndLegacyMedia();
    });

    displayTimeReport();
})();