Fixed emotes
Fixed public server button not showing
Changed public server api endpoint
Added public server description, tags and category search
Added mutation listener for settings panel instead of relying on defers
Fixed many small bugs
This commit is contained in:
Jiiks 2016-05-21 12:19:29 +03:00
parent 512ccd1904
commit 13c1ab4be0
4 changed files with 685 additions and 301 deletions

View File

@ -536,6 +536,16 @@
display: block; display: block;
} }
#bd-changelog {
float: right;
height: 30px;
line-height: 30px;
margin-right: 10px;
font-size: 11px;
font-weight: 700;
cursor:pointer;
}
.fav { .fav {
display: none; display: none;
position: absolute; position: absolute;
@ -947,10 +957,58 @@
#pubs-header input, #pubs-header button { #pubs-header input, #pubs-header button {
float: right; float: right;
} }
#pubs-sterm {
outline:none !important;
padding-left:3px;
}
.bd-dropdown {
position:absolute;
display:inline-block;
width:150px;
right:225px;
}
.bd-dropdown button {
width:150px;
}
.bd-dropdown .bd-dropdown-list ul {
height:0;
}
.bd-dropdown.open .bd-dropdown-list ul {
height:140px;
}
.bd-dropdown-list {
position:absolute;
right:0;
top:32px;
z-index:90001;
width:150px;
background:#F3F3F3;
}
.bd-dropdown-list ul {
height:0;
overflow-y:auto;
overflow-x:hidden;
transition: all 0.5s ease-in-out;
}
.bd-dropdown-list ul li {
padding:5px;
background:#E6E6E6;
cursor:pointer;
color:#87909c;
font-weight:600;
}
.bd-dropdown-list ul li:nth-child(odd) {
background:#E2E1E1;
}
.bd-dropdown-list ul li:hover {
background:#F9F5F5;
}
#pubs-header input { #pubs-header input {
border: none; border: none;
height: 30px; height: 30px;
width: 100px; width: 150px;
color: #555; color: #555;
background-color: #fff; background-color: #fff;
-webkit-transition: width 1s ease-in-out; -webkit-transition: width 1s ease-in-out;
@ -958,9 +1016,7 @@
-o-transition: width 1s ease-in-out; -o-transition: width 1s ease-in-out;
transition: width 1s ease-in-out; transition: width 1s ease-in-out;
} }
#pubs-header input:focus {
width: 300px;
}
#pubs-header button { #pubs-header button {
height: 32px; height: 32px;
background-color: #f9f9f9; background-color: #f9f9f9;
@ -983,6 +1039,9 @@
text-decoration: none; text-decoration: none;
font-weight: 800; font-weight: 800;
} }
#pubs-container .scroller-wrap {
margin-top: 75px;
}
.server-row { .server-row {
padding: 5px; padding: 5px;
@ -1027,8 +1086,12 @@
.server-info button:hover { .server-info button:hover {
background-color: #697ec4; background-color: #697ec4;
} }
.server-information {
flex-grow:1;
position:relative;
}
.server-name { .server-name, .server-desription {
flex-grow: 100; flex-grow: 100;
} }
.server-name span { .server-name span {
@ -1037,11 +1100,88 @@
max-width: 300px; max-width: 300px;
white-space: nowrap; white-space: nowrap;
} }
.server-name-span, .server-description {
position:absolute;
top:0;
transition: visibility 0s, opacity 0.8s linear;
}
.server-official, .server-tags {
visibility:visible;
opacity:1;
transition: visibility 0s, opacity 0.8s linear;
}
.server-information:hover .server-description {
visibility: visible;
opacity: 1;
}
.server-information:hover .server-name-span {
visibility: hidden;
opacity: 0;
}
.server-information:hover .server-tags {
visibility: hidden;
opacity: 0;
}
.server-information:hover .server-official {
visibility:hidden;
opacity:0;
}
.server-tags {
position: absolute !important;
bottom: 0 !important;
height: 38px !important;
font-size: 10px !important;
visibility: visible;
opacity: 1;
}
.server-official {
position:absolute !important;
top:0 !important;
height:20px !important;
font-size:14px !important;
line-height:14px !important;
color: #7289DA !important;
font-weight: 700 !important;
text-shadow: 0px 0px 4px #7289DA;
visibility: visible;
opacity: 1;
padding-left:2px;
padding-right:2px;
}
.server-description {
visibility:hidden;
opacity:0;
font-size: 12px !important;
line-height: 12px !important;
text-overflow: initial !important;
white-space: inherit !important;
overflow-y: auto !important;
height: 64px !important;
}
.server-region { .server-region {
min-width: 85px; min-width: 85px;
} }
.server-pinned {
position: absolute;
width: 777px;
padding-right: -10px;
padding-right: 17px;
border-bottom: 2px solid #272727;
}
#server-bd-tag {
position: absolute !important;
bottom: 0 !important;
height: 20px !important;
line-height: 20px !important;
font-size: 13px !important;
font-weight: 600 !important;
}
#pubs-spinner { #pubs-spinner {
position: fixed; position: fixed;
top: 50%; top: 50%;
@ -1218,6 +1358,63 @@
display: none; display: none;
} }
.bd-select select {
width: 100%;
margin: 0;
outline: none;
padding: .6em .8em .5em .8em;
-webkit-box-sizing: border-box;
box-sizing: border-box;
font-size: 14px;
padding-right: 2em;
background: none;
border: 1px solid transparent !important;
-webkit-appearance: none;
appearance: none;
color:#404040;
outline:none !important;
}
.bd-select::after {
content: " ";
position: absolute;
top: 50%;
right: 1em;
z-index: 2;
pointer-events: none;
display: none;
}
.bd-select select:focus {
border-color: #aaa;
}
.bd-select:focus::after {
display:block;
}
.bd-select {
position: absolute;
right:220px;
height:32px;
top: 5px;
border-radius:0;
display:inline-block;
border: none;
border-radius: 0;
box-shadow: 0 1px 0 1px rgba(0,0,0,.04);
background: #fff;
outline:none !important;
}
.bd-select:before {
content: "Category";
color:#FFF;
position:absolute;
right:100%;
margin-right:5px;
line-height:32px;
}
#bd-pane .tab-bar.TOP { #bd-pane .tab-bar.TOP {
margin-bottom:0; margin-bottom:0;
} }
@ -1381,11 +1578,18 @@
background: #353535; background: #353535;
border-color: #202020; border-color: #202020;
} }
.bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar, .bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-track, .bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-track-piece { .bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar,
.bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-track,
.bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-track-piece,
.bda-dark #pubs-container .scroller::-webkit-scrollbar,
.bda-dark #pubs-container .scroller::-webkit-scrollbar-track,
.bda-dark #pubs-container .scroller::-webkit-scrollbar-track-piece {
background-color: #303030 !important; background-color: #303030 !important;
border-color: #303030 !important; border-color: #303030 !important;
} }
.bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar, .bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-track, .bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-track-piece { .bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar,
.bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-track,
.bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-track-piece {
background-color: #303030 !important; background-color: #303030 !important;
border-color: #303030 !important; border-color: #303030 !important;
} }
@ -1393,9 +1597,67 @@
background-color: #303030 !important; background-color: #303030 !important;
border-color: #303030 !important; border-color: #303030 !important;
} }
.bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-thumb, .bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-thumb, .bda-dark .emoji-picker .scroller::-webkit-scrollbar-thumb { .bda-dark #bda-qem-twitch-container .scroller::-webkit-scrollbar-thumb,
.bda-dark #bda-qem-favourite-container .scroller::-webkit-scrollbar-thumb,
.bda-dark .emoji-picker .scroller::-webkit-scrollbar-thumb,
.bda-dark #pubs-container .scroller::-webkit-scrollbar-thumb {
border-color: #202020 !important; border-color: #202020 !important;
background-color: #202020 !important; background-color: #202020 !important;
} }
.bda-dark .server-row {
background-color:#36393E;
}
.bda-dark .server-row:nth-child(odd), .bda-dark #pubs-container {
background-color:#2E3136;
}
.bda-dark .server-info span {
color:#D6D6D6;
}
.bda-dark #pubs-header,
.bda-dark #pubs-footer{
background:#202020;
}
.bda-dark #pubs-sterm {
background:#36393E;
color:#FFF;
}
.bda-dark #pubs-searchbtn {
background:#2E3136;
}
.bda-dark .bd-select {
background:#36393E;
}
.bda-dark .server-info button {
background-color:#202020;
}
.bda-dark #pubs-cat {
color:#FFF;
}
.bda-dark .bd-dropdown-select {
background-color:#2E3136;
}
.bda-dark .bd-dropdown-list ul li:nth-child(odd) {
background:#36393E;
}
.bda-dark .bd-dropdown-list ul li {
background:#3D4046;
}
.bda-dark .bd-dropdown-list ul li:hover {
background:#2D2F33;
}
.bda-dark #pubs-header button {
background-color:#2E3136;
}
.bda-dark .bd-dropdown .bd-dropdown-list ul::-webkit-scrollbar,
.server-description::-webkit-scrollbar {
width: 12px;
}
.bda-dark .bd-dropdown .bd-dropdown-list ul::-webkit-scrollbar-track,
.server-description::-webkit-scrollbar-track {
background:#303030;
}
.bda-dark .bd-dropdown .bd-dropdown-list ul::-webkit-scrollbar-thumb,
.server-description::-webkit-scrollbar-thumb {
background:#202020;
}
/*# sourceMappingURL=main.css.map */ /*# sourceMappingURL=main.css.map */

2
css/main.min.css vendored

File diff suppressed because one or more lines are too long

View File

@ -6,7 +6,7 @@
* https://github.com/Jiiks/BetterDiscordApp * https://github.com/Jiiks/BetterDiscordApp
*/ */
var settingsPanel, emoteModule, utils, quickEmoteMenu, opublicServers, voiceMode, pluginModule, themeModule, customCssEditor; var settingsPanel, emoteModule, utils, quickEmoteMenu, opublicServers, voiceMode, pluginModule, themeModule, customCssEditor;
var jsVersion = 1.71; var jsVersion = 1.72;
var supportedVersion = "0.2.5"; var supportedVersion = "0.2.5";
var mainObserver; var mainObserver;
@ -80,57 +80,87 @@ var defaultCookie = {
var bdchangelog = { var bdchangelog = {
"changes": { "changes": {
"ttv": { "a": {
"title": "v1.72 : Public Servers",
"text": "Public servers now have categories, description, tags, dark mode and more!",
"img": ""
},
"b": {
"title": "v1.72 : Import/Export",
"text": "Import/Export buttons now disappear in themes/plugins tabs to avoid confusion",
"img": ""
},
"c": {
"title": "v1.72 : Changelog",
"text": "You can now reopen this changelog from the settings",
"img": ""
},
"d": {
"title": "v1.71 : Hide Twitch emotes", "title": "v1.71 : Hide Twitch emotes",
"text": "Hide all emotes option now toggles Twitch emotes instead!", "text": "Hide all emotes option now toggles Twitch emotes instead!",
"img": "" "img": ""
}, },
"bttv": { "e": {
"title": "v1.71 : Override FFZ emote", "title": "v1.71 : Override FFZ emote",
"text": "Use the <code class=\"inline\">:bttv</code> emote modifier to override a FFZ emote with a BTTV one!", "text": "Use the <code class=\"inline\">:bttv</code> emote modifier to override a FFZ emote with a BTTV one!",
"img": "" "img": ""
}, },
"028s": { "f": {
"title": "v1.70 : 0.2.8 Support", "title": "v1.70 : 0.2.8 Support",
"text": "Added support for Core version 0.2.8.", "text": "Added support for Core version 0.2.8.",
"img": "" "img": ""
}, },
"importexport": { "g": {
"title": "v1.70 : Setting Import/Export", "title": "v1.70 : Setting Import/Export",
"text": "You can now import and export your settings!", "text": "You can now import and export your settings!",
"img": "" "img": ""
}, },
"infscroll": { "h": {
"title": "v1.70 : Public Server List Infinite Scroll", "title": "v1.70 : Public Server List Infinite Scroll",
"text": "Public server list now has the ability to load more than 20 servers.", "text": "Public server list now has the ability to load more than 20 servers.",
"img": "" "img": ""
}, },
"tstamps": { "i": {
"title": "v1.70 : 24 hour timestamps", "title": "v1.70 : 24 hour timestamps",
"text": "Replace 12 hour timestamp with 24 hour timestamps!", "text": "Replace 12 hour timestamp with 24 hour timestamps!",
"img": "" "img": ""
}, },
"ctext": { "j": {
"title": "v1.70 : Coloured text", "title": "v1.70 : Coloured text",
"text": "Make text colour the same as role colour!", "text": "Make text colour the same as role colour!",
"img": "" "img": ""
} }
}, },
"fixes": { "fixes": {
"emotes": { "a": {
"title": "v1.72 : Settings panel",
"text": "Settings panel will now show no matter how you open it!",
"img": ""
},
"b": {
"title": "v1.72 : Fixed emote edit bug",
"text": "Edits now appear properly even with emotes!",
"img": ""
},
"c": {
"title": "v1.72 : Public servers",
"text": "Public servers button is visible again!",
"img": ""
},
"d": {
"title": "v1.72 : Public servers",
"text": "Updated public servers api endpoint url for fetching correct serverlist.",
"img": ""
},
"e": {
"title": "v1.71 : Fixed emotes and edit", "title": "v1.71 : Fixed emotes and edit",
"text": "Emotes work again! So does editing emotes!", "text": "Emotes work again! So does editing emotes!",
"img": "" "img": ""
}, },
"spoiler": { "f": {
"title": "Spoilers are currently broken :(", "title": "Spoilers are currently broken :(",
"text": "Ps. I know this in the fixes section :o", "text": "Ps. I know this in the fixes section :o",
"img": "" "img": ""
},
"pserver": {
"title": "v1.64 : Public Server Owner",
"text": "Removed undefined server owner property",
"imt": ""
} }
} }
}; };
@ -270,7 +300,11 @@ Core.prototype.loadSettings = function () {
var botlist = ["119598467310944259"]; //Temp var botlist = ["119598467310944259"]; //Temp
Core.prototype.initObserver = function () { Core.prototype.initObserver = function () {
mainObserver = new MutationObserver(function (mutations) { mainObserver = new MutationObserver(function (mutations) {
mutations.forEach(function (mutation) { mutations.forEach(function (mutation) {
if(settingsPanel !== undefined)
settingsPanel.inject(mutation);
if($(mutation.target).find(".emoji-picker").length) { if($(mutation.target).find(".emoji-picker").length) {
var fc = mutation.target.firstChild; var fc = mutation.target.firstChild;
if(fc.classList.contains("popout")) { if(fc.classList.contains("popout")) {
@ -306,7 +340,7 @@ Core.prototype.initObserver = function () {
} }
matches[2] = ('0' + h).slice(-2); matches[2] = ('0' + h).slice(-2);
t.text(matches[1] + matches[2] + ":" + matches[3]); t.text(matches[1] + " at " + matches[2] + ":" + matches[3]);
}); });
} }
if(settingsCookie["bda-gs-7"]) { if(settingsCookie["bda-gs-7"]) {
@ -499,11 +533,16 @@ EmoteModule.prototype.obsCallback = function (mutation) {
var nodes = self.getNodes(next); var nodes = self.getNodes(next);
for (var node in nodes) { for (var node in nodes) {
if (nodes.hasOwnProperty(node)) { if (nodes.hasOwnProperty(node)) {
var elem = nodes[node].parentElement;
if (elem && elem.classList.contains('edited')) {
self.injectEmote(elem);
} else {
self.injectEmote(nodes[node]); self.injectEmote(nodes[node]);
} }
} }
} }
} }
}
}; };
EmoteModule.prototype.getNodes = function (node) { EmoteModule.prototype.getNodes = function (node) {
@ -515,173 +554,167 @@ EmoteModule.prototype.getNodes = function (node) {
while (next = treeWalker.nextNode()) { while (next = treeWalker.nextNode()) {
nodes.push(next); nodes.push(next);
} }
return nodes; return nodes;
}; };
var bemotes = []; var bemotes = [];
var spoilered = []; var spoilered = [];
EmoteModule.prototype.injectEmote = function (node) {
if (typeof emotesTwitch === 'undefined') return; EmoteModule.prototype.injectEmote = function(node) {
var self = this;
if (!node.parentElement) return; if (!node.parentElement) return;
var parent = $(node).parent();
var parent = node.parentElement; if(!parent.hasClass("markup") && !parent.hasClass("message-content")) return;
if (!$(parent).hasClass("markup")) {
return;
}
var edited = false;
function inject() { function inject() {
var p = $(parent); var contents = parent.contents();
var parentInnerHTML = p.html();
var words = parentInnerHTML.split(/\s+/g);
var injected = false;
if (!words) return;
var oldHeight = parent.parentElement.offsetHeight;
words.forEach(function (word) {
var w = word.replace("-->", "").replace("<!--", ""); 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);
if (w.slice(0, 4) == "[!s]") { var words = nodeValue.split(/([^\s]+)([\s]|$)/g).filter(function(e){ return e});
parentInnerHTML = parentInnerHTML.replace("[!s]", ""); var splice = 0;
var markup = $(parent).parent();
var reactId = markup.attr("data-reactid");
if (spoilered.indexOf(reactId) > -1) { var doInject = false;
return; var text = null;
words.forEach(function(w, index, a) {
if(w.indexOf("[!s]") > -1) {
w = w.replace("[!s]", "");
parent.data("spoilered", false);
parent.addClass("spoiler");
} }
markup.addClass("spoiler"); var allowedClasses = ["flip", "spin", "pulse", "spin2", "spin3", "1spin", "2spin", "3spin", "tr", "bl", "br", "shake", "shake2", "shake3", "flap"];
markup.on("click", function () { var useEmoteClass = false;
$(this).removeClass("spoiler");
spoilered.push($(this).attr("data-reactid"));
});
return;
}
if (w.length < 4) {
return;
}
if (w == "ClauZ") {
parentInnerHTML = parentInnerHTML.replace("ClauZ", '<img src="https://cdn.frankerfacez.com/emoticon/70852/1" style="width:25px; transform:translate(-29px, -14px);"></img>');
return;
}
var skipffz = false;
var useEmoteCss = false;
var sWord = w;
var emoteClass = ""; var emoteClass = "";
var allowedClasses = ["emoteflip", "emotespin", "emotepulse", "emotespin2", "emotespin3", "emote1spin", "emote2spin", "emote3spin", "emotetr", "emotebl", "emotebr", "emoteshake", "emoteshake2", "emoteshake3", "emoteflap"]; var skipffz = false;
var sw = w;
if(w.indexOf(":") > -1) { if(w.indexOf(":") > -1) {
var split = w.split(/:(?!.*:)/); var split = w.split(":");
if (split[0] != "" && split[1] != "") { if(split[0] != "" && split[1] != "") {
userEmoteCss = true; if(allowedClasses.indexOf(split[1]) > -1) {
sWord = split[0]; sw = split[0];
emoteClass = settingsCookie["bda-es-8"] ? "emote" + split[1] : "";
}
if(split[1] == "bttv") {
sw = split[0];
skipffz = true;
}
}
}
//check for bttv mod if ($.inArray(sw, bemotes) != -1) return;
if(split[1] == "bttv") skipffz = true;
if(settingsCookie["bda-es-8"]) { if(typeof emotesTwitch !== 'undefind' && settingsCookie["bda-es-7"]) {
emoteClass = "emote" + split[1]; if(emotesTwitch.emotes.hasOwnProperty(sw) && sw.length >= 4) {
if(allowedClasses.indexOf(emoteClass) < 0) { if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
emoteClass = ""; var url = twitchEmoteUrlStart + emotesTwitch.emotes[sw].image_id + twitchEmoteUrlEnd;
} contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
} doInject = true;
}
}
if ($.inArray(sWord, bemotes) != -1) return;
if (emotesTwitch.emotes.hasOwnProperty(sWord) && settingsCookie["bda-es-7"]) {
var len = Math.round(sWord.length / 4);
var name = sWord.substr(0, len) + "\uFDD9" + sWord.substr(len, len) + "\uFDD9" + sWord.substr(len * 2, len) + "\uFDD9" + sWord.substr(len * 3);
var url = twitchEmoteUrlStart + emotesTwitch.emotes[sWord].image_id + twitchEmoteUrlEnd;
parentInnerHTML = parentInnerHTML.replace(w, '<div class="emotewrapper"><img class="emote '+emoteClass+'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></div>');
injected = true;
return; return;
} }
}
if (subEmotesTwitch.hasOwnProperty(sWord)) { if(typeof subEmotesTwitch !== 'undefined' && settingsCookie["bda-es-7"]) {
var len = Math.round(sWord.length / 4); if(subEmotesTwitch.hasOwnProperty(sw) && sw.length >= 4) {
var name = sWord.substr(0, len) + "\uFDD9" + sWord.substr(len, len) + "\uFDD9" + sWord.substr(len * 2, len) + "\uFDD9" + sWord.substr(len * 3); if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
var url = twitchEmoteUrlStart + subEmotesTwitch[sWord] + twitchEmoteUrlEnd; var url = twitchEmoteUrlStart + subEmotesTwitch[sw] + twitchEmoteUrlEnd;
parentInnerHTML = parentInnerHTML.replace(w, '<div class="emotewrapper"><img class="emote '+emoteClass+'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></div>'); contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
injected = true; doInject = true;
return; return;
} }
}
if (typeof emotesBTTV !== 'undefined' && settingsCookie["bda-es-2"]) { if (typeof emotesBTTV !== 'undefined' && settingsCookie["bda-es-2"]) {
if (emotesBTTV.hasOwnProperty(sWord)) { if(emotesBTTV.hasOwnProperty(sw) && sw.length >= 4) {
var len = Math.round(sWord.length / 4); if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
var name = sWord.substr(0, len) + "\uFDD9" + sWord.substr(len, len) + "\uFDD9" + sWord.substr(len * 2, len) + "\uFDD9" + sWord.substr(len * 3); var url = emotesBTTV[sw];
var url = emotesBTTV[sWord]; contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
parentInnerHTML = parentInnerHTML.replace(w, '<div class="emotewrapper"><img class="emote '+emoteClass+'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></div>'); doInject = true;
injected = true;
return; return;
} }
} }
if (typeof emotesFfz !== 'undefined' && settingsCookie["bda-es-1"]) { if ((typeof emotesFfz !== 'undefined' && settingsCookie["bda-es-1"]) && (!skipffz || !emotesBTTV2.hasOwnProperty(sw))) {
//only skip ffz if there is a bttv emote for it if(emotesFfz.hasOwnProperty(sw) && sw.length >= 4) {
if(!skipffz || !emotesBTTV2.hasOwnProperty(sWord)){ if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
if (emotesFfz.hasOwnProperty(sWord)) { var url = ffzEmoteUrlStart + emotesFfz[sw] + ffzEmoteUrlEnd;
var len = Math.round(sWord.length / 4); contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
var name = sWord.substr(0, len) + "\uFDD9" + sWord.substr(len, len) + "\uFDD9" + sWord.substr(len * 2, len) + "\uFDD9" + sWord.substr(len * 3); doInject = true;
var url = ffzEmoteUrlStart + emotesFfz[sWord] + ffzEmoteUrlEnd;
parentInnerHTML = parentInnerHTML.replace(w, '<div class="emotewrapper"><img class="emote '+emoteClass+'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></div>');
injected = true;
return; return;
} }
} }
}
if (typeof emotesBTTV2 !== 'undefined' && settingsCookie["bda-es-2"]) { if (typeof emotesBTTV2 !== 'undefined' && settingsCookie["bda-es-2"]) {
if (emotesBTTV2.hasOwnProperty(sWord)) { if(emotesBTTV2.hasOwnProperty(sw) && sw.length >= 4) {
var len = Math.round(sWord.length / 4); if(text != null) { contents.splice(i + splice++, 0, document.createTextNode(text)); text = null;}
var name = sWord.substr(0, len) + "\uFDD9" + sWord.substr(len, len) + "\uFDD9" + sWord.substr(len * 2, len) + "\uFDD9" + sWord.substr(len * 3); var url = bttvEmoteUrlStart + emotesBTTV2[sw] + bttvEmoteUrlEnd;
if(skipffz && emotesFfz.hasOwnProperty(sw)) sw = sw + ":bttv";
//if bttv emote is forced change its name for fav. and tooltip and to be able to copy them with the mod contents.splice(i + splice++, 0, self.createEmoteElement(sw, url, emoteClass));
if (skipffz) name = w.substr(0, len) + "\uFDD9" + w.substr(len, len) + "\uFDD9" + w.substr(len * 2, len) + "\uFDD9" + w.substr(len * 3); doInject = true;
var url = bttvEmoteUrlStart + emotesBTTV2[sWord] + bttvEmoteUrlEnd;
parentInnerHTML = parentInnerHTML.replace(w, '<div class="emotewrapper"><img class="emote '+emoteClass+'" alt="' + name + '" src="' + url + '"/><input onclick=\'quickEmoteMenu.favorite(\"' + name + '\", \"' + url + '\");\' class="fav" title="Favorite!" type="button"></div>');
injected = true;
return; return;
} }
} }
}); if(text == null) {
if(!injected) return; text = w;
if (parent.parentElement == null) return; } else {
text += "" + w;
parent.innerHTML = parentInnerHTML.replace(/(<!.*?react.*?>)/g, "").replace(new RegExp("\uFDD9", "g"), "");
var newHeight = parent.parentElement.offsetHeight;
var scrollPane = $(".scroller.messages").first();
scrollPane.scrollTop(scrollPane.scrollTop() + (newHeight - oldHeight));
} }
setTimeout(inject, 300); if(index === a.length - 1) {
contents.splice(i + splice, 0, document.createTextNode(text));
}
});
if(doInject) {
var oldHeight = parent.outerHeight();
parent.html(contents);
var scrollPane = $(".scroller.messages").first();
scrollPane.scrollTop(scrollPane.scrollTop() + (parent.outerHeight() - oldHeight));
}
});
}
inject();
if(parent.children().hasClass("edited")) {
setTimeout(inject, 250);
}
};
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];
}; };
EmoteModule.prototype.autoCapitalize = function () { EmoteModule.prototype.autoCapitalize = function () {
var self = this; var self = this;
$('body').delegate($(".channel-textarea-inner textarea"), 'keyup change paste', function () { $('body').delegate($(".channel-textarea-inner textarea:first"), 'keyup change paste', function () {
if (!settingsCookie["bda-es-4"]) return; if (!settingsCookie["bda-es-4"]) return;
var text = $(".channel-textarea-inner textarea").val(); var text = $(".channel-textarea-inner textarea:first").val();
if (text == undefined) return; if (text == undefined) return;
var lastWord = text.split(" ").pop(); var lastWord = text.split(" ").pop();
@ -689,7 +722,7 @@ EmoteModule.prototype.autoCapitalize = function () {
if (lastWord == "danSgame") return; if (lastWord == "danSgame") return;
var ret = self.capitalize(lastWord.toLowerCase()); var ret = self.capitalize(lastWord.toLowerCase());
if (ret !== null && ret !== undefined) { if (ret !== null && ret !== undefined) {
$(".channel-textarea-inner textarea").val(text.replace(lastWord, ret)); $(".channel-textarea-inner textarea:first").val(text.replace(lastWord, ret));
} }
} }
}); });
@ -720,12 +753,15 @@ PublicServers.prototype.getPanel = function () {
}; };
PublicServers.prototype.init = function () { PublicServers.prototype.init = function () {
this.filtered = ["134680912691462144", "86004744966914048"];
this.bdServer = null;
this.loadingServers = false; this.loadingServers = false;
var self = this; var self = this;
var guilds = $(".guilds>li:first-child"); var guilds = $(".guilds>:first-child");
guilds.after($("<li></li>", { guilds.after($("<div></div>", {
class: "guild",
id: "bd-pub-li", id: "bd-pub-li",
css: { css: {
"height": "20px", "height": "20px",
@ -765,6 +801,38 @@ PublicServers.prototype.init = function () {
<h2 id="pubs-header-title">Public Servers</h2>\ <h2 id="pubs-header-title">Public Servers</h2>\
<button id="pubs-searchbtn">Search</button>\ <button id="pubs-searchbtn">Search</button>\
<input id="pubs-sterm" type="text" placeholder="Search Term...">\ <input id="pubs-sterm" type="text" placeholder="Search Term...">\
<div id="pubs-select-dropdown" class="bd-dropdown">\
<button class="bd-dropdown-select" id="pubs-cat-select">All</button>\
<div class="bd-dropdown-list">\
<ul>\
<li class="pubs-cat-select-li" data-val="all">All</li>\
<li class="pubs-cat-select-li" data-val="1">FPS Games</li>\
<li class="pubs-cat-select-li" data-val="2">MMO Games</li>\
<li class="pubs-cat-select-li" data-val="3">MOBA Games</li>\
<li class="pubs-cat-select-li" data-val="4">Strategy Games</li>\
<li class="pubs-cat-select-li" data-val="5">Sports Games</li>\
<li class="pubs-cat-select-li" data-val="6">Puzzle Games</li>\
<li class="pubs-cat-select-li" data-val="7">Retro Games</li>\
<li class="pubs-cat-select-li" data-val="8">Party Games</li>\
<li class="pubs-cat-select-li" data-val="9">Tabletop Games</li>\
<li class="pubs-cat-select-li" data-val="10">Sandbox Games</li>\
<li class="pubs-cat-select-li" data-val="11">Community</li>\
<li class="pubs-cat-select-li" data-val="12">Language</li>\
<li class="pubs-cat-select-li" data-val="13">Programming</li>\
<li class="pubs-cat-select-li" data-val="14">Other</li>\
<li class="pubs-cat-select-li" data-val="15">Simulation Games</li>\
</ul>\
</div>\
</div>\
</div>\
<div class="server-row server-pinned" style="display:none;">\
<div class="server-icon" style="background-image:url(https://cdn.discordapp.comi/cons/86004744966914048/6e5729ed5c12d5af558d80d7a194c3f9.jpg)"></div>\
<div class="server-info server-name"><span>BetterDiscord</span><span id="server-bd-tag">Official BetterDiscord server</span></div>\
<div class="server-info server-members"><span></span></div>\
<div class="server-info server-region"><span></span></div>\
<div class="server-info">\
<button data-server-invite-code="0WrILkb5M80rqxl4">Join</button>\
</div>\
</div>\ </div>\
<div class="scroller-wrap">\ <div class="scroller-wrap">\
<div class="scroller" id="pubs-scroller">\ <div class="scroller" id="pubs-scroller">\
@ -783,6 +851,7 @@ PublicServers.prototype.init = function () {
</div>\ </div>\
</div>\ </div>\
<div id="pubs-footer">\ <div id="pubs-footer">\
<span style="color:#FFF; font-size:10px; font-weight:700; margin-left:5px;">Tip: Hover over server name for description if available</span>\
<div>Server list provided by <a href="https://discordservers.com" target="_blank">DiscordServers.com</a></div>\ <div>Server list provided by <a href="https://discordservers.com" target="_blank">DiscordServers.com</a></div>\
</div>\ </div>\
'; ';
@ -796,35 +865,94 @@ PublicServers.prototype.init = function () {
} }
}; };
PublicServers.prototype.show = function () { PublicServers.prototype.getPinnedServer = function() {
var self = this; var self = this;
$("body").append(this.getPanel());
var dataset = { var dataset = {
"sort": [{ "sort": [{"online": "desc"}],
"online": "desc" "size": 1,
}],
"from": 0,
"size": 20,
"query": { "query": {
"filtered": { "query_string": {
"query": { "default_operator": "AND",
"match_all": {} "query": "BetterDiscord"
}
} }
} }
}; };
$("#pubs-searchbtn").on("click", function() { $.ajax({
self.search(); type: "POST",
}); dataType: "json",
$("#pubs-sterm").on("keyup", function(e) { url: "https://search-discordservers-izrtub5nprzrl76ugyy6hdooe4.us-west-1.es.amazonaws.com/discord_servers/_search",
if (e.keyCode == 13) { crossDomain: true,
self.search(); data: JSON.stringify(dataset),
success: function(data) {
try {
var s = data.hits.hits[0]._source;
if(s.identifier == "86004744966914048") {
self.bdServer = s;
self.showPinnedServer();
}
}catch(err) {
self.bdServer = null;
}
} }
}); });
};
PublicServers.prototype.hidePinnedServer = function() {
$("#pubs-container .scroller-wrap").css({"margin-top": "0", "height": "500px"});
$(".server-pinned").hide();
};
PublicServers.prototype.showPinnedServer = function() {
$(".server-pinned .server-icon").css("background-image", "url("+this.bdServer.icon+")");
$(".server-pinned .server-members span").text(this.bdServer.online + "/"+this.bdServer.members+" Members");
$(".server-pinned .server-region span").text(this.bdServer.region);
$(".server-pinned .server-info button").data("server-invite-code", this.bdServer.invite_code);
$("#pubs-container .scroller-wrap").css({"margin-top": "75px", "height": "425px"});
$(".server-pinned").show();
};
PublicServers.prototype.show = function () {
var self = this;
this.hidePinnedServer();
$("#pubs-cat-select").text("All");
this.selectedCategory = "all";
$("#pubs-container .scroller-wrap").css({"margin-top": "0", "height": "500px"});
$(".server-pinned").hide();
$(".app").append(this.getPanel());
if(this.bdServer == null) {
this.getPinnedServer();
} else {
this.showPinnedServer();
}
self.search(0, true);
$("#pubs-searchbtn").off("click").on("click", function() {
self.search();
});
$("#pubs-sterm").off("keyup").on("keyup", function(e) {
if (e.keyCode == 13) {
self.search(0, true);
}
});
$("#pubs-cat-select").off("click").on("click", function() {
$("#pubs-select-dropdown").addClass("open");
});
$(".pubs-cat-select-li").off("click").on("click", function() {
$("#pubs-select-dropdown").removeClass("open");
$("#pubs-cat-select").text($(this).text());
if(self.selectedCategory != $(this).data("val")) {
self.selectedCategory = $(this).data("val");
self.search(0, true);
}
});
$("#pubs-container").off("mouseup").on("mouseup", function() {
$("#pubs-select-dropdown").removeClass("open");
});
this.loadServers(dataset, false, true);
var self = this; var self = this;
$(document).on("mouseup.bdps",function(e) { $(document).on("mouseup.bdps",function(e) {
if(!$("#bd-pub-button").is(e.target) && !$("#pubs-container").is(e.target) && $("#pubs-container").has(e.target).length === 0) { if(!$("#bd-pub-button").is(e.target) && !$("#pubs-container").is(e.target) && $("#pubs-container").has(e.target).length === 0) {
@ -840,38 +968,7 @@ PublicServers.prototype.show = function () {
self.loadingServers = true; self.loadingServers = true;
$("#pubs-spinner-bottom").show(); $("#pubs-spinner-bottom").show();
var dataset = { self.search(list.children().length, false);
"sort": [{
"online": "desc"
}],
"from": list.children().length,
"size": 20,
"query": {
"filtered": {
"query": {
"match_all": {}
}
}
}
};
var filter = {
"filter": {
"and": [{
"query": {
"match_phrase_prefix": {
"name": $("#pubs-sterm").val()
}
}
}]
}
};
if ($("#pubs-sterm").val()) {
$.extend(dataset, filter);
}
self.loadServers(dataset, true, false);
}); });
}; };
@ -880,6 +977,7 @@ PublicServers.prototype.hide = function() {
$(document).off("mouseup.bdps"); $(document).off("mouseup.bdps");
}; };
PublicServers.prototype.loadServers = function(dataset, search, clear) { PublicServers.prototype.loadServers = function(dataset, search, clear) {
this.loadingServers = true; this.loadingServers = true;
var self = this; var self = this;
@ -890,7 +988,7 @@ PublicServers.prototype.loadServers = function(dataset, search, clear) {
$.ajax({ $.ajax({
type: "POST", type: "POST",
dataType: "json", dataType: "json",
url: "https://search-discordservers-izrtub5nprzrl76ugyy6hdooe4.us-west-1.es.amazonaws.com/app/_search", url: "https://search-discordservers-izrtub5nprzrl76ugyy6hdooe4.us-west-1.es.amazonaws.com/discord_servers/_search",
crossDomain: true, crossDomain: true,
data: JSON.stringify(dataset), data: JSON.stringify(dataset),
success: function(data) { success: function(data) {
@ -904,11 +1002,26 @@ PublicServers.prototype.loadServers = function(dataset, search, clear) {
hits.forEach(function(hit) { hits.forEach(function(hit) {
var source = hit._source; var source = hit._source;
var icode = source.invite_code; var icode = source.invite_code.replace(/ /g,'');
var html = '<div class="server-row">'; var html = '<div class="server-row">';
html += '<div class="server-icon" style="background-image:url(' + source.icon + ')"></div>'; html += '<div class="server-icon" style="background-image:url(' + source.icon + ')"></div>';
html += '<div class="server-info server-name">'; html += '<div class="server-info server-name">';
html += '<span>' + source.name + '</span>'; html += '<div class="server-information">';
if(source.is_official) {
html += '<span class="server-official">Official!</span>';
}
html += '<span class="server-name-span">' + source.name + '</span>';
var tags = [];
source.categories.forEach(function(tag) {
tags.push(tag.name);
});
html += '<span class="server-tags">'+tags.join(", ")+'</span>';
html += '<span class="server-description">'+(source.description == undefined ? "No Description" : source.description)+'</span>';
html += '</div>';
html += '</div>'; html += '</div>';
html += '<div class="server-info server-members">'; html += '<div class="server-info server-members">';
html += '<span>' + source.online + '/' + source.members + ' Members</span>'; html += '<span>' + source.online + '/' + source.members + ' Members</span>';
@ -961,38 +1074,38 @@ PublicServers.prototype.loadServers = function(dataset, search, clear) {
}); });
}; };
PublicServers.prototype.search = function() { PublicServers.prototype.search = function(start, clear) {
var sterm = $("#pubs-sterm").val();
var dataset = { var dataset = {
"sort": [{ "sort": [{ "online": "desc" }],
"online": "desc" "from": start,
}],
"from": 0,
"size": 20, "size": 20,
"query": { "query": {
"filtered": { "filtered": {
"query": { "query": {
"match_all": {} "query_string": {
"default_operator": "AND",
"query": sterm ? sterm : "*"
} }
} },
}
};
var filter = {
"filter": { "filter": {
"and": [{ "bool": {
"query": { "must_not": [{
"match_phrase_prefix": { "terms": {
"name": $("#pubs-sterm").val() "identifier": this.filtered
}
} }
}] }]
} }
};
if ($("#pubs-sterm").val()) {
$.extend(dataset, filter);
} }
this.loadServers(dataset, true, true); }
}
};
if(this.selectedCategory != "all") {
dataset.query.filtered.filter.bool.must = [{ "term": { "categories.id": this.selectedCategory } }]
}
this.loadServers(dataset, true, clear);
}; };
//Workaround for joining a server //Workaround for joining a server
@ -1085,7 +1198,7 @@ QuickEmoteMenu.prototype.favContext = function(e, em) {
e.preventDefault(); e.preventDefault();
e.stopPropagation(); e.stopPropagation();
$(this).remove(); $(this).remove();
console.log($(this).data("emoteid"));
delete quickEmoteMenu.favoriteEmotes[$(this).data("emoteid")]; delete quickEmoteMenu.favoriteEmotes[$(this).data("emoteid")];
quickEmoteMenu.updateFavorites(); quickEmoteMenu.updateFavorites();
return false; return false;
@ -1346,7 +1459,7 @@ SettingsPanel.prototype.init = function () {
var title = $(this).attr("alt"); var title = $(this).attr("alt");
$(emoteNamePopup).find(".tipsy-inner").text(title); $(emoteNamePopup).find(".tipsy-inner").text(title);
$(emoteNamePopup).css('left', x.left - 25); $(emoteNamePopup).css('left', x.left - 25);
$(emoteNamePopup).css('top', x.top - 32); $(emoteNamePopup).css('top', x.top - 37);
$(".app").append($(emoteNamePopup)); $(".app").append($(emoteNamePopup));
}); });
$(document).on("mouseleave", ".emote", function () { $(document).on("mouseleave", ".emote", function () {
@ -1374,13 +1487,27 @@ SettingsPanel.prototype.changeTab = function (tab) {
switch (tab) { switch (tab) {
case "bd-settings-tab": case "bd-settings-tab":
$(".bda-slist-top").show();
break;
case "bd-emotes-tab":
$(".bda-slist-top").show();
break; break;
case "bd-customcss-tab": case "bd-customcss-tab":
$(".bda-slist-top").show();
if (!customCssInitialized) { if (!customCssInitialized) {
customCssEditor.init(); customCssEditor.init();
customCssInitialized = true; customCssInitialized = true;
} }
break; break;
case "bd-themes-tab":
$(".bda-slist-top").hide();
break;
case "bd-plugins-tab":
$(".bda-slist-top").hide();
break;
default:
$(".bda-slist-top").show();
break;
} }
}; };
@ -1669,6 +1796,7 @@ SettingsPanel.prototype.construct = function () {
<div style="background:#2E3136; color:#ADADAD; height:30px; position:absolute; bottom:0; left:0; right:0;">\ <div style="background:#2E3136; color:#ADADAD; height:30px; position:absolute; bottom:0; left:0; right:0;">\
<span style="line-height:30px;margin-left:10px;">BetterDiscord v' + ((typeof(version) == "undefined") ? bdVersion : version) + '(JSv' + jsVersion + ') by Jiiks</span>\ <span style="line-height:30px;margin-left:10px;">BetterDiscord v' + ((typeof(version) == "undefined") ? bdVersion : version) + '(JSv' + jsVersion + ') by Jiiks</span>\
<span style="float:right;line-height:30px;margin-right:10px;"><a href="http://betterdiscord.net" target="_blank">BetterDiscord.net</a></span>\ <span style="float:right;line-height:30px;margin-right:10px;"><a href="http://betterdiscord.net" target="_blank">BetterDiscord.net</a></span>\
<span id="bd-changelog" onclick=\'$("body").append(mainCore.constructChangelog());\'>changelog</span>\
</div>\ </div>\
</div></div>\ </div></div>\
'; ';
@ -1694,37 +1822,27 @@ SettingsPanel.prototype.construct = function () {
}); });
panel.html(settingsInner); panel.html(settingsInner);
this.panel = panel;
};
function defer() { SettingsPanel.prototype.inject = function(mutation) {
if ($(".btn.btn-settings").length < 1) { if(mutation.type != "childList") return;
setTimeout(defer, 100); if(mutation.addedNodes.length <= 0) return;
} else { if($(mutation.addedNodes[0]).find(".user-settings-modal").length <= 0) return;
$(".btn.btn-settings").first().on("click", function () {
function innerDefer() { var self = this;
if ($(".modal-inner").first().is(":visible")) { this.panel.hide();
panel.hide();
var tabBar = $(".tab-bar.SIDE").first(); var tabBar = $(".tab-bar.SIDE").first();
$(".tab-bar.SIDE .tab-bar-item").click(function () { $(".tab-bar.SIDE .tab-bar-item").click(function () {
$(".form .settings-right .settings-inner").first().show(); $(".form .settings-right .settings-inner").first().show();
$("#bd-settings-new").removeClass("selected"); $("#bd-settings-new").removeClass("selected");
panel.hide(); self.panel.hide();
}); });
tabBar.append(settingsButton); tabBar.append(settingsButton);
$(".form .settings-right .settings-inner").last().after(panel); $(".form .settings-right .settings-inner").last().after(self.panel);
$("#bd-settings-new").removeClass("selected"); $("#bd-settings-new").removeClass("selected");
} else {
setTimeout(innerDefer, 100);
}
}
innerDefer();
});
}
}
defer();
}; };
/* BetterDiscordApp Utilities JavaScript /* BetterDiscordApp Utilities JavaScript
@ -1788,11 +1906,11 @@ Utils.prototype.injectCss = function (uri) {
}; };
Utils.prototype.log = function (message) { Utils.prototype.log = function (message) {
console.info("%c[BetterDiscord]%c " + message, "color:teal; font-weight:bold;", ""); console.log('%c[%cBetterDiscord%c] %c'+message+'', 'color: red;', 'color: #303030; font-weight:700;', 'color:red;', '');
}; };
Utils.prototype.err = function (message) { Utils.prototype.err = function (message) {
console.info("%c[BetterDiscord]%c " + message, "color:red; font-weight:bold;", ""); console.log('%c[%cBetterDiscord%c] %c'+message+'', 'color: red;', 'color: red; font-weight:700;', 'color:red;', '');
}; };
Utils.prototype.importSettings = function() { Utils.prototype.importSettings = function() {

62
js/main.min.js vendored

File diff suppressed because one or more lines are too long