CW Game Time

Показывает время и дату

Bu betiği kurabilmeniz için Tampermonkey, Greasemonkey ya da Violentmonkey gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği yüklemek için Tampermonkey gibi bir uzantı yüklemeniz gerekir.

Bu betiği kurabilmeniz için Tampermonkey ya da Violentmonkey gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği kurabilmeniz için Tampermonkey ya da Userscripts gibi bir kullanıcı betiği eklentisini kurmanız gerekmektedir.

Bu betiği indirebilmeniz için ayrıca Tampermonkey gibi bir eklenti kurmanız gerekmektedir.

Bu betiği yüklemek için bir betik yöneticisi eklentisi yüklemeniz gerekecektir.

(Zaten bir betik yöneticim var, hadi yükleyelim!)

Advertisement:

Bu stili yüklemek için Stylus gibi bir uzantı yüklemeniz gerekir.

Bu stili yüklemek için Stylus gibi bir uzantı kurmanız gerekir.

Bu stili yükleyebilmek için Stylus gibi bir uzantı yüklemeniz gerekir.

Bu stili yüklemek için bir kullanıcı stili yöneticisi uzantısı yüklemeniz gerekir.

Bu stili yüklemek için bir kullanıcı stili yöneticisi uzantısı kurmanız gerekir.

Bu stili yükleyebilmek için bir kullanıcı stili yöneticisi uzantısı yüklemeniz gerekir.

(Zateb bir user-style yöneticim var, yükleyeyim!)

Advertisement:

// ==UserScript==
// @name         CW Game Time
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  Показывает время и дату
// @author       Why? Ева
// @match        https://playtest.cw-game.ru/play
// @icon         https://www.google.com/s2/favicons?sz=64&domain=cw-game.ru
// @grant        none
// ==/UserScript==

(function() {
    'use strict';
    function findPlace() {
        const targetDiv = document.querySelector(".css-1byqyzy");
        const dataRect = document.createElement('div');
        const timeRect = document.createElement('div');
        timeRect.id = 'timetime';
        dataRect.id = 'datadata';
        timeRect.style.cssText = "width: 52px; height: 30px; border-radius: 30px; margin-left: 7.99px; display: inline-block; background: rgba(10, 10, 20, 0.63); font-family: 'Neucha', Arial, sans-serif; color: #ffffff; text-align: center; line-height: 30px; font-size: 17px;"
        dataRect.style.cssText = "width: 52px; height: 30px; border-radius: 30px; margin-left: 7.99px; display: inline-block; background: rgba(10, 10, 20, 0.63); font-family: 'Neucha', Arial, sans-serif; color: #ffffff; text-align: center; line-height: 30px; font-size: 17px;"
        targetDiv.parentNode.insertBefore(timeRect, targetDiv.nextSibling);
        timeRect.parentNode.insertBefore(dataRect, timeRect.nextSibling);
    };

    function setTime() {
        const timeRect = document.getElementById('timetime');
        if (!timeRect) return;
        const game = (typeof unsafeWindow !== 'undefined' ? unsafeWindow.CWGPlayground : window.CWGPlayground);
        const virtualDate = game?.getVirtualTime?.().virtualDate || game?.virtualTime?.virtualDate;
        if (!virtualDate || virtualDate.hour === undefined || virtualDate.minute === undefined) {
            timeRect.textContent = "--:--";
            return;
        }
        const hour = String(virtualDate.hour).padStart(2, '0');
        const minute = String(virtualDate.minute).padStart(2, '0');
        timeRect.textContent = `${hour}:${minute}`;
    }

    function setData() {
        const dataRect = document.getElementById('datadata');
        if (!dataRect) return;
        const game = (typeof unsafeWindow !== 'undefined' ? unsafeWindow.CWGPlayground : window.CWGPlayground);
        const virtualDate = game?.getVirtualTime?.().virtualDate || game?.virtualTime?.virtualDate;
        if (!virtualDate || virtualDate.moon === undefined || virtualDate.date === undefined) {
            dataRect.textContent = "--:--";
            return;
        }
        let color = '#ffffff';
        if ((1 <= virtualDate.moon && virtualDate.moon <= 2) || virtualDate.moon == 12){
            color = '#7ad5ff';
        } else if (3 <= virtualDate.moon && virtualDate.moon <= 5){
            color = '#c8ffa8';
        } else if (6 <= virtualDate.moon && virtualDate.moon <= 8){
            color = '#a9ff7a';
        } else if (9 <= virtualDate.moon && virtualDate.moon <= 11){
            color = '#ff997a';
        }
        const day = String(virtualDate.date + 1).padStart(2, '0');
        const month = String(virtualDate.moon + 1).padStart(2, '0');
        dataRect.textContent = `${day}.${month}`;
        dataRect.style.color = color;
    }

    const checkInterval = setInterval(() => {
        if (document.querySelector(".css-1byqyzy")){
            clearInterval(checkInterval);
            findPlace();
            setTime();
            setData();
            setInterval(setTime, 2000);
        }
    }, 1000);
})();