Core rewrite
This commit is contained in:
parent
8a15d57e39
commit
3a365f30ed
117
dev/js/00core.js
117
dev/js/00core.js
|
@ -8,12 +8,6 @@
|
||||||
|
|
||||||
var BD;
|
var BD;
|
||||||
|
|
||||||
var settingsPanel, emoteModule, utils, quickEmoteMenu, opublicServers, voiceMode, pluginModule, themeModule, customCssEditor;
|
|
||||||
|
|
||||||
var mainObserver;
|
|
||||||
var mainCore;
|
|
||||||
var settingsCookie = {};
|
|
||||||
|
|
||||||
function Core() {
|
function Core() {
|
||||||
BD = this;
|
BD = this;
|
||||||
}
|
}
|
||||||
|
@ -21,30 +15,38 @@ function Core() {
|
||||||
Core.prototype.init = function () {
|
Core.prototype.init = function () {
|
||||||
var self = this;
|
var self = this;
|
||||||
this.version = version;
|
this.version = version;
|
||||||
this.jsVersion = jsVersion;
|
|
||||||
if (this.version < supportedVersion) {
|
if (this.version < bdConfig.versionInfo.supportedVersion) {
|
||||||
this.alert("Not Supported", "BetterDiscord v" + this.version + "(your version)" + " is not supported by the latest js(" + this.jsVersion + ").<br><br> Please download the latest version from <a href='https://betterdiscord.net' target='_blank'>BetterDiscord.net</a>");
|
this.alert("Not Supported", "BetterDiscord v" + this.version + "(your version)" + " is not supported by the latest js(" + bdConfig.versionInfo.version + ").<br><br> Please download the latest version from <a href='https://betterdiscord.net' target='_blank'>BetterDiscord.net</a>");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.utils = new Utils();
|
this.modules = {
|
||||||
|
emoteModule: new EmoteModule(),
|
||||||
|
publicServers: new PublicServers(),
|
||||||
|
emoteMenu: new QuickEmoteMenu(),
|
||||||
|
cssEditor: new customCssEditor(),
|
||||||
|
settingsPanel: new SettingsPanel(),
|
||||||
|
utils: new Utils(),
|
||||||
|
voiceMode: new VoiceMode(),
|
||||||
|
pluginModule: new pluginModule(),
|
||||||
|
themeModule: new ThemeModule()
|
||||||
|
}
|
||||||
|
|
||||||
utils = new Utils();
|
this.modules.utils.getHash();
|
||||||
utils.getHash();
|
|
||||||
emoteModule = new EmoteModule();
|
|
||||||
quickEmoteMenu = new QuickEmoteMenu();
|
|
||||||
voiceMode = new VoiceMode();
|
|
||||||
|
|
||||||
emoteModule.init();
|
this.modules.emoteModule.init();
|
||||||
|
|
||||||
this.initSettings();
|
this.initSettings();
|
||||||
this.initObserver();
|
this.initObserver();
|
||||||
|
|
||||||
|
|
||||||
//Incase were too fast
|
//Incase were too fast
|
||||||
function gwDefer() {
|
function gwDefer() {
|
||||||
console.log(new Date().getTime() + " Defer");
|
self.modules.utils.log(new Date().getTime() + " Defer");
|
||||||
|
|
||||||
if ($(".guilds-wrapper .guilds").children().length > 0) {
|
if ($(".guilds-wrapper .guilds").children().length > 0) {
|
||||||
console.log(new Date().getTime() + " Defer Loaded");
|
self.modules.utils.log(new Date().getTime() + " Defer Loaded");
|
||||||
var guilds = $(".guilds>li:first-child");
|
var guilds = $(".guilds>li:first-child");
|
||||||
|
|
||||||
var showChannelsButton = $("<button/>", {
|
var showChannelsButton = $("<button/>", {
|
||||||
|
@ -55,7 +57,7 @@ Core.prototype.init = function () {
|
||||||
"cursor": "pointer"
|
"cursor": "pointer"
|
||||||
},
|
},
|
||||||
click: function () {
|
click: function () {
|
||||||
settingsCookie["bda-gs-3"] = false;
|
self.settingsCookie["bda-gs-3"] = false;
|
||||||
$("body").removeClass("bd-minimal-chan");
|
$("body").removeClass("bd-minimal-chan");
|
||||||
self.saveSettings();
|
self.saveSettings();
|
||||||
}
|
}
|
||||||
|
@ -63,39 +65,29 @@ Core.prototype.init = function () {
|
||||||
|
|
||||||
$(".guilds-wrapper").prepend(showChannelsButton);
|
$(".guilds-wrapper").prepend(showChannelsButton);
|
||||||
|
|
||||||
opublicServers = new PublicServers();
|
self.modules.pluginModule.loadPlugins();
|
||||||
customCssEditor = new CustomCssEditor();
|
|
||||||
pluginModule = new PluginModule();
|
|
||||||
pluginModule.loadPlugins();
|
|
||||||
if (typeof (themesupport2) !== "undefined") {
|
if (typeof (themesupport2) !== "undefined") {
|
||||||
themeModule = new ThemeModule();
|
self.modules.themeModule.loadThemes();
|
||||||
themeModule.loadThemes();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
settingsPanel = new SettingsPanel();
|
self.modules.settingsPanel.init();
|
||||||
settingsPanel.init();
|
|
||||||
|
|
||||||
quickEmoteMenu.init(false);
|
self.modules.quickEmoteMenu.init(false);
|
||||||
|
|
||||||
$("#tc-settings-button").on("click", function () {
|
|
||||||
settingsPanel.show();
|
|
||||||
});
|
|
||||||
|
|
||||||
window.addEventListener("beforeunload", function(){
|
window.addEventListener("beforeunload", function(){
|
||||||
if(settingsCookie["bda-dc-0"]){
|
if(self.settingsCookie["bda-dc-0"]){
|
||||||
$('.btn.btn-disconnect').click();
|
$('.btn.btn-disconnect').click();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
self.modules.publicServers.init();
|
||||||
opublicServers.init();
|
self.modules.emoteModule.autoCapitalize();
|
||||||
|
|
||||||
emoteModule.autoCapitalize();
|
|
||||||
|
|
||||||
/*Display new features in BetterDiscord*/
|
/*Display new features in BetterDiscord*/
|
||||||
if (settingsCookie["version"] < jsVersion) {
|
if (self.settingsCookie["version"] < bdConfig.versionInfo.version) {
|
||||||
var cl = self.constructChangelog();
|
var cl = self.constructChangelog();
|
||||||
$("body").append(cl);
|
$("body").append(cl);
|
||||||
settingsCookie["version"] = jsVersion;
|
self.settingsCookie["version"] = bdConfig.versionInfo.version;
|
||||||
self.saveSettings();
|
self.saveSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,14 +107,14 @@ Core.prototype.init = function () {
|
||||||
|
|
||||||
Core.prototype.initSettings = function () {
|
Core.prototype.initSettings = function () {
|
||||||
if ($.cookie("better-discord") == undefined) {
|
if ($.cookie("better-discord") == undefined) {
|
||||||
settingsCookie = defaultCookie;
|
this.settingsCookie = bdConfig.defaults;
|
||||||
this.saveSettings();
|
this.saveSettings();
|
||||||
} else {
|
} else {
|
||||||
this.loadSettings();
|
this.loadSettings();
|
||||||
|
|
||||||
for (var setting in defaultCookie) {
|
for (var setting in defaultCookie) {
|
||||||
if (settingsCookie[setting] == undefined) {
|
if (this.settingsCookie[setting] == undefined) {
|
||||||
settingsCookie[setting] = defaultCookie[setting];
|
this.settingsCookie[setting] = bdConfig.defaults[setting];
|
||||||
this.saveSettings();
|
this.saveSettings();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,38 +122,39 @@ Core.prototype.initSettings = function () {
|
||||||
};
|
};
|
||||||
|
|
||||||
Core.prototype.saveSettings = function () {
|
Core.prototype.saveSettings = function () {
|
||||||
$.cookie("better-discord", JSON.stringify(settingsCookie), {
|
$.cookie("better-discord", JSON.stringify(this.settingsCookie), {
|
||||||
expires: 365,
|
expires: 365,
|
||||||
path: '/'
|
path: '/'
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
Core.prototype.loadSettings = function () {
|
Core.prototype.loadSettings = function () {
|
||||||
settingsCookie = JSON.parse($.cookie("better-discord"));
|
this.settingsCookie = JSON.parse($.cookie("better-discord"));
|
||||||
};
|
};
|
||||||
|
|
||||||
Core.prototype.initObserver = function () {
|
Core.prototype.initObserver = function () {
|
||||||
mainObserver = new MutationObserver(function (mutations) {
|
var self = this;
|
||||||
|
this.observer = new MutationObserver(function (mutations) {
|
||||||
mutations.forEach(function (mutation) {
|
mutations.forEach(function (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")) {
|
||||||
quickEmoteMenu.obsCallback($(fc));
|
self.modules.quickEmoteMenu.obsCallback($(fc));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (typeof pluginModule !== "undefined") pluginModule.rawObserver(mutation);
|
if (typeof pluginModule !== "undefined") self.modules.pluginModule.rawObserver(mutation);
|
||||||
if (mutation.target.getAttribute('class') != null) {
|
if (mutation.target.getAttribute('class') != null) {
|
||||||
//console.log(mutation.target)
|
//console.log(mutation.target)
|
||||||
if(mutation.target.classList.contains('title-wrap') || mutation.target.classList.contains('chat')){
|
if(mutation.target.classList.contains('title-wrap') || mutation.target.classList.contains('chat')){
|
||||||
// quickEmoteMenu.obsCallback();
|
// quickEmoteMenu.obsCallback();
|
||||||
voiceMode.obsCallback();
|
self.modules.voiceMode.obsCallback();
|
||||||
if (typeof pluginModule !== "undefined") pluginModule.channelSwitch();
|
if (typeof pluginModule !== "undefined") self.modules.pluginModule.channelSwitch();
|
||||||
}
|
}
|
||||||
if (mutation.target.getAttribute('class').indexOf('scroller messages') != -1) {
|
if (mutation.target.getAttribute('class').indexOf('scroller messages') != -1) {
|
||||||
if (typeof pluginModule !== "undefined") pluginModule.newMessage();
|
if (typeof self.modules.pluginModule !== "undefined") self.modules.pluginModule.newMessage();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
emoteModule.obsCallback(mutation);
|
self.modules.emoteModule.obsCallback(mutation);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -184,15 +177,15 @@ Core.prototype.constructChangelog = function () {
|
||||||
' <div class="scroller-wrap">' +
|
' <div class="scroller-wrap">' +
|
||||||
' <div class="scroller">';
|
' <div class="scroller">';
|
||||||
|
|
||||||
if (bdchangelog.changes != null) {
|
if (bdConfig.changelog.changes != null) {
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<h1 class="changelog-added">' +
|
'<h1 class="changelog-added">' +
|
||||||
' <span>New Stuff</span>' +
|
' <span>New Stuff</span>' +
|
||||||
'</h1>' +
|
'</h1>' +
|
||||||
'<ul>';
|
'<ul>';
|
||||||
|
|
||||||
for (var change in bdchangelog.changes) {
|
for (var change in bdConfig.changelog.changes) {
|
||||||
change = bdchangelog.changes[change];
|
change = bdConfig.changelog.changes[change];
|
||||||
|
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<li>' +
|
'<li>' +
|
||||||
|
@ -204,15 +197,15 @@ Core.prototype.constructChangelog = function () {
|
||||||
changeLog += '</ul>';
|
changeLog += '</ul>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bdchangelog.fixes != null) {
|
if (bdConfig.changelog.fixes != null) {
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<h1 class="changelog-fixed">' +
|
'<h1 class="changelog-fixed">' +
|
||||||
' <span>Fixed</span>' +
|
' <span>Fixed</span>' +
|
||||||
'</h1>' +
|
'</h1>' +
|
||||||
'<ul>';
|
'<ul>';
|
||||||
|
|
||||||
for (var fix in bdchangelog.fixes) {
|
for (var fix in bdConfig.changelog.fixes) {
|
||||||
fix = bdchangelog.fixes[fix];
|
fix = bdConfig.changelog.fixes[fix];
|
||||||
|
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<li>' +
|
'<li>' +
|
||||||
|
@ -224,15 +217,15 @@ Core.prototype.constructChangelog = function () {
|
||||||
changeLog += '</ul>';
|
changeLog += '</ul>';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bdchangelog.upcoming != null) {
|
if (bdConfig.changelog.upcoming != null) {
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<h1 class="changelog-in-progress">' +
|
'<h1 class="changelog-in-progress">' +
|
||||||
' <span>Coming Soon</span>' +
|
' <span>Coming Soon</span>' +
|
||||||
'</h1>' +
|
'</h1>' +
|
||||||
'<ul>';
|
'<ul>';
|
||||||
|
|
||||||
for (var upc in bdchangelog.upcoming) {
|
for (var upc in bdConfig.changelog.upcoming) {
|
||||||
upc = bdchangelog.upcoming[upc];
|
upc = bdConfig.changelog.upcoming[upc];
|
||||||
|
|
||||||
changeLog += '' +
|
changeLog += '' +
|
||||||
'<li>' +
|
'<li>' +
|
||||||
|
@ -270,7 +263,3 @@ Core.prototype.alert = function (title, text) {
|
||||||
' </div>' +
|
' </div>' +
|
||||||
'</div>');
|
'</div>');
|
||||||
};
|
};
|
||||||
|
|
||||||
Core.prototype.getUtils = function() {
|
|
||||||
return this.utils;
|
|
||||||
};
|
|
Loading…
Reference in New Issue