2015-08-26 10:47:30 +02:00
|
|
|
/* BetterDiscordApp EmoteModule JavaScript
|
2015-10-26 06:27:55 +01:00
|
|
|
* Version: 1.5
|
2015-08-26 10:47:30 +02:00
|
|
|
* Author: Jiiks | http://jiiks.net
|
2015-08-27 15:28:43 +02:00
|
|
|
* Date: 26/08/2015 - 15:29
|
2015-10-14 08:50:34 +02:00
|
|
|
* Last Update: 14/10/2015 - 09:48
|
2015-08-26 10:47:30 +02:00
|
|
|
* https://github.com/Jiiks/BetterDiscordApp
|
2015-08-26 16:21:02 +02:00
|
|
|
* Note: Due to conflicts autocapitalize only supports global emotes
|
2015-08-26 10:47:30 +02:00
|
|
|
*/
|
2015-08-25 13:26:36 +02:00
|
|
|
|
2015-10-26 06:27:55 +01:00
|
|
|
/*
|
|
|
|
* =Changelog=
|
|
|
|
* -v1.5
|
|
|
|
* --Twitchemotes.com api
|
|
|
|
*/
|
|
|
|
|
2015-08-26 16:21:02 +02:00
|
|
|
var emotesFfz = {};
|
|
|
|
var emotesBTTV = {};
|
2016-04-10 14:43:27 +02:00
|
|
|
var emotesTwitch = {
|
|
|
|
"emotes": {
|
|
|
|
"emote": {
|
|
|
|
"image_id": 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}; //for ide
|
2015-10-26 06:27:55 +01:00
|
|
|
var subEmotesTwitch = {};
|
2015-08-25 13:26:36 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
function EmoteModule() {}
|
2015-08-26 14:52:48 +02:00
|
|
|
|
2016-04-18 13:00:33 +02:00
|
|
|
EmoteModule.prototype.init = function () {};
|
2015-08-29 08:55:06 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
EmoteModule.prototype.getBlacklist = function () {
|
|
|
|
$.getJSON("https://cdn.rawgit.com/Jiiks/betterDiscordApp/" + _hash + "/data/emotefilter.json", function (data) {
|
|
|
|
bemotes = data.blacklist;
|
|
|
|
});
|
2015-12-16 12:21:46 +01:00
|
|
|
};
|
2015-08-25 14:43:53 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
EmoteModule.prototype.obsCallback = function (mutation) {
|
2015-08-29 08:55:06 +02:00
|
|
|
var self = this;
|
2015-12-16 12:21:46 +01:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
//if (!settingsCookie["bda-es-7"]) return;
|
2016-04-10 14:43:27 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
$(".emoji").each(function() {
|
2016-04-10 14:43:27 +02:00
|
|
|
var t = $(this);
|
2016-05-22 18:40:07 +02:00
|
|
|
if(t.attr("src").indexOf(".png") != -1) {
|
|
|
|
t.replaceWith(t.attr("alt"));
|
2016-04-10 14:43:27 +02:00
|
|
|
}
|
|
|
|
});
|
2015-12-16 12:21:46 +01:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
for (var i = 0; i < mutation.addedNodes.length; ++i) {
|
2015-08-29 08:55:06 +02:00
|
|
|
var next = mutation.addedNodes.item(i);
|
2016-04-10 14:43:27 +02:00
|
|
|
if (next) {
|
2015-08-29 08:55:06 +02:00
|
|
|
var nodes = self.getNodes(next);
|
2016-04-10 14:43:27 +02:00
|
|
|
for (var node in nodes) {
|
|
|
|
if (nodes.hasOwnProperty(node)) {
|
2016-05-22 18:40:07 +02:00
|
|
|
var elem = nodes[node].parentElement;
|
|
|
|
if (elem && elem.classList.contains('edited')) {
|
|
|
|
self.injectEmote(elem);
|
|
|
|
} else {
|
|
|
|
self.injectEmote(nodes[node]);
|
|
|
|
}
|
2015-10-26 06:27:55 +01:00
|
|
|
}
|
2015-08-29 08:55:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-10-26 06:27:55 +01:00
|
|
|
};
|
2015-08-25 14:43:53 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
EmoteModule.prototype.getNodes = function (node) {
|
2015-08-25 14:56:32 +02:00
|
|
|
var next;
|
|
|
|
var nodes = [];
|
2015-08-25 14:43:53 +02:00
|
|
|
|
2015-08-25 14:56:32 +02:00
|
|
|
var treeWalker = document.createTreeWalker(node, NodeFilter.SHOW_TEXT, null, false);
|
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
while (next = treeWalker.nextNode()) {
|
2015-08-25 14:56:32 +02:00
|
|
|
nodes.push(next);
|
|
|
|
}
|
|
|
|
return nodes;
|
2015-10-26 06:27:55 +01:00
|
|
|
};
|
2015-08-26 14:52:48 +02:00
|
|
|
|
2015-12-16 12:21:46 +01:00
|
|
|
var bemotes = [];
|
|
|
|
var spoilered = [];
|
|
|
|
|
2015-08-25 14:56:32 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
EmoteModule.prototype.injectEmote = function(node) {
|
|
|
|
var self = this;
|
2015-08-25 14:56:32 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
if (!node.parentElement) return;
|
2016-05-22 18:40:07 +02:00
|
|
|
var parent = $(node).parent();
|
|
|
|
|
|
|
|
if(!parent.hasClass("markup") && !parent.hasClass("message-content")) return;
|
2015-08-25 14:56:32 +02:00
|
|
|
|
|
|
|
|
2015-12-16 12:21:46 +01:00
|
|
|
function inject() {
|
2016-05-22 18:40:07 +02:00
|
|
|
var contents = parent.contents();
|
|
|
|
|
|
|
|
contents.each(function(i) {
|
|
|
|
if(contents[i] == undefined) return;
|
|
|
|
var nodeValue = contents[i].nodeValue;
|
|
|
|
if(nodeValue == null) return;
|
|
|
|
//if(nodeValue.indexOf("react-") > -1) return;
|
|
|
|
if(contents[i].nodeType == 8) return;
|
|
|
|
contents.splice(i, 1);
|
|
|
|
|
|
|
|
var words = nodeValue.split(/([^\s]+)([\s]|$)/g).filter(function(e){ return e});
|
|
|
|
|
|
|
|
var splice = 0;
|
2015-12-16 12:21:46 +01:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
var doInject = false;
|
|
|
|
var text = null;
|
2016-04-10 14:43:27 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
words.forEach(function(w, index, a) {
|
|
|
|
|
|
|
|
if(w.indexOf("[!s]") > -1) {
|
|
|
|
w = w.replace("[!s]", "");
|
|
|
|
parent.data("spoilered", false);
|
|
|
|
parent.addClass("spoiler");
|
2015-12-16 12:21:46 +01:00
|
|
|
}
|
2016-05-22 18:40:07 +02:00
|
|
|
|
|
|
|
var allowedClasses = ["flip", "spin", "pulse", "spin2", "spin3", "1spin", "2spin", "3spin", "tr", "bl", "br", "shake", "shake2", "shake3", "flap"];
|
|
|
|
var useEmoteClass = false;
|
|
|
|
var emoteClass = "";
|
|
|
|
var skipffz = false;
|
|
|
|
|
|
|
|
var sw = w;
|
|
|
|
|
|
|
|
if(w.indexOf(":") > -1) {
|
|
|
|
var split = w.split(":");
|
|
|
|
if(split[0] != "" && split[1] != "") {
|
|
|
|
if(allowedClasses.indexOf(split[1]) > -1) {
|
|
|
|
sw = split[0];
|
|
|
|
emoteClass = settingsCookie["bda-es-8"] ? "emote" + split[1] : "";
|
|
|
|
}
|
|
|
|
if(split[1] == "bttv") {
|
|
|
|
sw = split[0];
|
|
|
|
skipffz = true;
|
2016-04-10 14:43:27 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-05-22 18:40:07 +02:00
|
|
|
|
|
|
|
if ($.inArray(sw, bemotes) != -1) return;
|
|
|
|
|
|
|
|
if(typeof emotesTwitch !== 'undefind' && settingsCookie["bda-es-7"]) {
|
|
|
|
if(emotesTwitch.emotes.hasOwnProperty(sw) && sw.length >= 4) {
|
|
|
|
if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
|
|
|
|
var url = twitchEmoteUrlStart + emotesTwitch.emotes[sw].image_id + twitchEmoteUrlEnd;
|
|
|
|
contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
|
|
|
|
doInject = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(typeof subEmotesTwitch !== 'undefined' && settingsCookie["bda-es-7"]) {
|
|
|
|
if(subEmotesTwitch.hasOwnProperty(sw) && sw.length >= 4) {
|
|
|
|
if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
|
|
|
|
var url = twitchEmoteUrlStart + subEmotesTwitch[sw] + twitchEmoteUrlEnd;
|
|
|
|
contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
|
|
|
|
doInject = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof emotesBTTV !== 'undefined' && settingsCookie["bda-es-2"]) {
|
|
|
|
if(emotesBTTV.hasOwnProperty(sw) && sw.length >= 4) {
|
|
|
|
if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
|
|
|
|
var url = emotesBTTV[sw];
|
|
|
|
contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
|
|
|
|
doInject = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((typeof emotesFfz !== 'undefined' && settingsCookie["bda-es-1"]) && (!skipffz || !emotesBTTV2.hasOwnProperty(sw))) {
|
|
|
|
if(emotesFfz.hasOwnProperty(sw) && sw.length >= 4) {
|
|
|
|
if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
|
|
|
|
var url = ffzEmoteUrlStart + emotesFfz[sw] + ffzEmoteUrlEnd;
|
|
|
|
contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
|
|
|
|
doInject = true;
|
|
|
|
return;
|
|
|
|
}
|
2015-12-16 12:21:46 +01:00
|
|
|
}
|
2016-04-10 14:43:27 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
if (typeof emotesBTTV2 !== 'undefined' && settingsCookie["bda-es-2"]) {
|
|
|
|
if(emotesBTTV2.hasOwnProperty(sw) && sw.length >= 4) {
|
|
|
|
if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
|
|
|
|
var url = bttvEmoteUrlStart + emotesBTTV2[sw] + bttvEmoteUrlEnd;
|
|
|
|
if(skipffz && emotesFfz.hasOwnProperty(sw)) sw = sw + ":bttv";
|
|
|
|
contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
|
|
|
|
doInject = true;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(text == null) {
|
|
|
|
text = w;
|
|
|
|
} else {
|
|
|
|
text += "" + w;
|
2016-04-11 09:41:17 +02:00
|
|
|
}
|
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
if(index === a.length - 1) {
|
|
|
|
contents.splice(i + splice, 0, document.createTextNode(text));
|
2015-12-16 12:21:46 +01:00
|
|
|
}
|
2016-05-22 18:40:07 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
if(doInject) {
|
|
|
|
var oldHeight = parent.outerHeight();
|
|
|
|
parent.html(contents);
|
|
|
|
var scrollPane = $(".scroller.messages").first();
|
|
|
|
scrollPane.scrollTop(scrollPane.scrollTop() + (parent.outerHeight() - oldHeight));
|
2015-12-16 12:21:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
2016-04-10 14:43:27 +02:00
|
|
|
}
|
2016-05-22 18:40:07 +02:00
|
|
|
|
|
|
|
inject();
|
|
|
|
if(parent.children().hasClass("edited")) {
|
2016-04-10 14:43:27 +02:00
|
|
|
setTimeout(inject, 250);
|
|
|
|
}
|
2016-05-22 18:40:07 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
EmoteModule.prototype.createEmoteElement = function(word, url, mod) {
|
|
|
|
var len = Math.round(word.length / 4);
|
|
|
|
var name = word.substr(0, len) + "\uFDD9" + word.substr(len, len) + "\uFDD9" + word.substr(len * 2, len) + "\uFDD9" + word.substr(len * 3);
|
|
|
|
var html = '<span class="emotewrapper"><img draggable="false" style="max-height:32px;" class="emote '+ mod +'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></span>';
|
|
|
|
return $.parseHTML(html.replace(new RegExp("\uFDD9", "g"), ""))[0];
|
2015-10-26 06:27:55 +01:00
|
|
|
};
|
2015-08-26 16:21:02 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
EmoteModule.prototype.autoCapitalize = function () {
|
2015-12-16 12:21:46 +01:00
|
|
|
|
2015-08-26 16:21:02 +02:00
|
|
|
var self = this;
|
2015-08-31 15:36:28 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
$('body').delegate($(".channel-textarea-inner textarea:first"), 'keyup change paste', function () {
|
2016-04-10 14:43:27 +02:00
|
|
|
if (!settingsCookie["bda-es-4"]) return;
|
2015-08-26 18:39:04 +02:00
|
|
|
|
2016-05-22 18:40:07 +02:00
|
|
|
var text = $(".channel-textarea-inner textarea:first").val();
|
2016-04-10 14:43:27 +02:00
|
|
|
if (text == undefined) return;
|
2015-08-29 10:48:20 +02:00
|
|
|
|
2015-08-26 16:21:02 +02:00
|
|
|
var lastWord = text.split(" ").pop();
|
2016-04-10 14:43:27 +02:00
|
|
|
if (lastWord.length > 3) {
|
|
|
|
if (lastWord == "danSgame") return;
|
2015-08-26 16:21:02 +02:00
|
|
|
var ret = self.capitalize(lastWord.toLowerCase());
|
2016-04-10 14:43:27 +02:00
|
|
|
if (ret !== null && ret !== undefined) {
|
2016-05-22 18:40:07 +02:00
|
|
|
$(".channel-textarea-inner textarea:first").val(text.replace(lastWord, ret));
|
2015-08-26 16:21:02 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2015-10-26 06:27:55 +01:00
|
|
|
};
|
2015-08-26 16:21:02 +02:00
|
|
|
|
2016-04-10 14:43:27 +02:00
|
|
|
EmoteModule.prototype.capitalize = function (value) {
|
2015-12-16 12:21:46 +01:00
|
|
|
var res = emotesTwitch.emotes;
|
2016-04-10 14:43:27 +02:00
|
|
|
for (var p in res) {
|
|
|
|
if (res.hasOwnProperty(p) && value == (p + '').toLowerCase()) {
|
2015-12-16 12:21:46 +01:00
|
|
|
return p;
|
|
|
|
}
|
2015-08-26 16:21:02 +02:00
|
|
|
}
|
2015-10-26 06:27:55 +01:00
|
|
|
};
|