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