Adds wcat

Allows users in DGG Chat to see the wcat emote. Credit to yuniDev for writing the original version for cabge which i stole and replaced with wcat

Dovrai installare un'estensione come Tampermonkey, Greasemonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Violentmonkey per installare questo script.

Dovrai installare un'estensione come Tampermonkey o Userscripts per installare questo script.

Dovrai installare un'estensione come ad esempio Tampermonkey per installare questo script.

Dovrai installare un gestore di script utente per installare questo script.

(Ho già un gestore di script utente, lasciamelo installare!)

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione come ad esempio Stylus per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

Dovrai installare un'estensione per la gestione degli stili utente per installare questo stile.

(Ho già un gestore di stile utente, lasciamelo installare!)

// ==UserScript==
// @name         Adds wcat
// @namespace    devon
// @version      1.2
// @description  Allows users in DGG Chat to see the wcat emote. Credit to yuniDev for writing the original version for cabge which i stole and replaced with wcat
// @author       devon
// @match        https://www.destiny.gg/embed/chat*
// @match        https://www.destiny.gg/chat*
// @match        https://www.destiny.gg/bigscreen*
// @grant        GM_addStyle
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';

    // Base emote style
    GM_addStyle(`
        .emote.wcat {
            width: 32px;
            height: 32px;
            background-image: url();
        }
    `);

    // Default positioning tweak
    GM_addStyle(`
        .msg-chat .emote.wcat {
            margin-top: -32px;
            top: 7.5px;
        }
    `);

    // --- Custom shifts by timestamp suffix ---
    const timestampEmoteShifts = [
        { endsWith: '2', emote: 'wcat', x: -32, y: 0 },
        { endsWith: '5', emote: 'wcat', x: -32, y: 0 },
        { endsWith: '8', emote: 'wcat', x: -32, y: 0 },
        { endsWith: '3', emote: 'wcat', x: -96, y: 0 },
        { endsWith: '6', emote: 'wcat', x: -96, y: 0 },
        { endsWith: '9', emote: 'wcat', x: -96, y: 0 },
        { endsWith: '10', emote: 'wcat', x: -64, y: 0 },

        // Add more rules here
    ];

    timestampEmoteShifts.forEach(({ endsWith, emote, x, y }) => {
        GM_addStyle(`
            .msg-chat.msg-user > time[data-unixtimestamp$="${endsWith}"] ~ .text .emote.${emote}:first-of-type {
                height: 32px;
                width: 32px;
                background-position: ${x}px ${y}px;
                background-repeat: no-repeat;
            }
        `);
    });

    // --- Mutation observer to replace "wcat" text with emote ---
    function mutationCallback(mutationsList) {
        for (const mutation of mutationsList) {
            if (mutation.type === 'childList' && mutation.addedNodes.length > 0) {
                for (const addedNode of mutation.addedNodes) {
                    const textContainer = addedNode.querySelector(".text");
                    if (textContainer) {
                      textContainer.innerHTML = textContainer.innerHTML.replace(
                          /(^|\s|>)wcat(?=\s|$|<)/g,
                          `$1<div class="emote wcat">
                              <div class="emote-info">
                                  <div class="name" title="Emote name">wcat</div>
                              </div>
                           </div>`
                      );
                    }
                }
            }
        }
    }



    const targetElement = document.getElementById("chat-win-main")?.querySelector(".chat-lines");
    if (targetElement) {
        const observer = new MutationObserver(mutationCallback);
        observer.observe(targetElement, { childList: true });
    }
})();