// ==UserScript==
// @name IdlePixel Chat Highlighter
// @namespace lbtechnology.info
// @version 1.3.0
// @description Highlights messages containing specified words.
// @author Lux-Ferre
// @license MIT
// @match *://idle-pixel.com/login/play*
// @grant none
// @require https://gf.qytechs.cn/scripts/441206-idlepixel/code/IdlePixel+.js?anticache=20220905
// ==/UserScript==
(function() {
'use strict';
class HighlightPlugin extends IdlePixelPlusPlugin {
constructor() {
super("highlighting", {
about: {
name: GM_info.script.name,
version: GM_info.script.version,
author: GM_info.script.author,
description: GM_info.script.description
},
config: [{
type: "label",
label: "Message Highlighting:"
},
{
id: "wordList",
label: "List of trigger words (separate each trigger word with a comma.)",
type: "string",
max: 2000,
default: ""
},
{
id: "soundsEnabled",
label: "Play a sound when being pinged?",
type: "boolean",
default: false
},
{
id: "ignoreCase",
label: "Ignore case-sensitivity?",
type: "boolean",
default: true
},
{
id: "notificationsEnabled",
label: "Enable popup notifications?",
type: "boolean",
default: false
},
{
id: "considerSpaces",
label: "Allow spaces in triggers?",
type: "boolean",
default: false
},
{
id: "activeName",
label: "Username for account having sound & popups (only useful if you have multiple accounts open.)",
type: "string",
max: 20,
default: ""
},
{
id: "friendList",
label: "List of people to be highlighted (separate each name with a comma.)",
type: "string",
max: 2000,
default: ""
}
]
});
this.previous = "";
}
addHighlightedMessage(message, highlightType) {
const username = message.username;
const sigil = message.sigil;
const level = message.level;
const chatMessage = message.message;
let highlightColour = ""
if(highlightType === "word") {highlightColour = "rgba(0, 255, 0, 0.15)"}
else if(highlightType === "friend") {highlightColour = "rgba(140, 0, 255, 0.15)"}
else {highlightColour = "rgba(0, 0, 0, 0)"}
const newMessage = `<div style="background-color: ${highlightColour}"><span class="color-green">${Chat._get_time()} </span> <img src="https://d1xsc8x7nc5q8t.cloudfront.net/images/${sigil}.png"> <span class=""></span> <a target="_blank" class="chat-username" href="https://idle-pixel.com/hiscores/search?username=${username}" style="color: rgb(198, 70, 0);">${username}</a><span class="color-grey"> (${level}): </span>${chatMessage}</div>`
$("#chat-area").append(newMessage);
}
highlightMessage(data, type){
const notificationsEnabled = this.getConfig("notificationsEnabled");
const soundsEnabled = this.getConfig("soundsEnabled");
const activeName = this.getConfig("activeName");
const element = $("#chat-area > *").last();
this.addHighlightedMessage(data, type);
element.remove();
if (activeName == var_username || activeName == ""){
if (soundsEnabled){Sounds.play(Sounds.VARIABLE_POWER_UP);}
if (notificationsEnabled){this.notify(data.message, data.username)}
}
}
notify(message, username){
if (!window.Notification) {
alert("Sorry, Notifications are not supported in this Browser!");
} else {
if (Notification.permission === 'default') {
Notification.requestPermission(function(p) {
if (p === 'denied') {
alert('You have denied Notifications'); }
else {
var notify = new Notification('Chat Notification', {
body: `${username}: ${message}`,
requireInteraction: true,
icon: bob
});
}
});
} else {
var notify = new Notification('Chat Notification', {
body: `${username}: ${message}`,
icon: bob,
requireInteraction: true
});
}
}
}
processWordList(rawWordList){ //Just for you, Morgan
if(rawWordList.charAt(rawWordList.length - 1) === ","){rawWordList = rawWordList.slice(0, -1);}
if(this.getConfig("considerSpaces")){
return rawWordList
} else {
return rawWordList.replace(/\s+/g, '');
}
}
onChat(data) {
const ignoreCase = this.getConfig("ignoreCase");
let rawWordList = this.getConfig("wordList");
const friendList = this.getConfig("friendList");
var message
var wordList
rawWordList = this.processWordList(rawWordList).split(',');
if (ignoreCase) {
message = data.message.toLowerCase();
wordList = rawWordList.map(word => word.toLowerCase());
}
else {
message = data.message;
wordList = rawWordList;
}
if (wordList.some(word => message.includes(word)) && wordList != "") {
this.highlightMessage(data, "word");
} else if (friendList.includes(data.username) && friendList != ""){
this.highlightMessage(data, "friend");
}
}
}
const plugin = new HighlightPlugin();
var bob = ""
IdlePixelPlus.registerPlugin(plugin);
})();