BetterDiscordApp-v2/dev/js/02emoteModule.js

257 lines
9.4 KiB
JavaScript
Raw Normal View History

2015-08-26 10:47:30 +02:00
/* BetterDiscordApp EmoteModule JavaScript
* 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
/*
* =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
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-08-29 08:55:06 +02: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-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-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-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
}
};