EditChannels now uses patching instead of observing
This commit is contained in:
parent
5b45fc7c67
commit
dcb831c97b
|
@ -4,7 +4,14 @@ class EditChannels {
|
||||||
initConstructor () {
|
initConstructor () {
|
||||||
this.labels = {};
|
this.labels = {};
|
||||||
|
|
||||||
this.updateChannels = false;
|
this.moduleTypes = {
|
||||||
|
"ChannelTextArea":"componentDidMount",
|
||||||
|
"AuditLog":"componentDidMount",
|
||||||
|
"ChannelCategoryItem":"componentDidMount",
|
||||||
|
"ChannelItem":"componentDidMount",
|
||||||
|
"HeaderBar":["componentDidMount","componentDidUpdate"],
|
||||||
|
"Clickable":"componentDidMount"
|
||||||
|
};
|
||||||
|
|
||||||
this.channelContextEntryMarkup =
|
this.channelContextEntryMarkup =
|
||||||
`<div class="${BDFDB.disCN.contextmenuitemgroup}">
|
`<div class="${BDFDB.disCN.contextmenuitemgroup}">
|
||||||
|
@ -84,8 +91,7 @@ class EditChannels {
|
||||||
this.defaults = {
|
this.defaults = {
|
||||||
settings: {
|
settings: {
|
||||||
changeChannelIcon: {value:true, description:"Change color of Channel Icon."},
|
changeChannelIcon: {value:true, description:"Change color of Channel Icon."},
|
||||||
changeUnreadIndicator: {value:true, description:"Change color of Unread Indicator."},
|
changeUnreadIndicator: {value:true, description:"Change color of Unread Indicator."}
|
||||||
changeInChannelHeader: {value:true, description:"Change in Channel Header."}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -94,7 +100,7 @@ class EditChannels {
|
||||||
|
|
||||||
getDescription () {return "Allows you to rename and recolor channelnames.";}
|
getDescription () {return "Allows you to rename and recolor channelnames.";}
|
||||||
|
|
||||||
getVersion () {return "3.8.2";}
|
getVersion () {return "3.8.3";}
|
||||||
|
|
||||||
getAuthor () {return "DevilBro";}
|
getAuthor () {return "DevilBro";}
|
||||||
|
|
||||||
|
@ -114,7 +120,12 @@ class EditChannels {
|
||||||
|
|
||||||
$(settingspanel)
|
$(settingspanel)
|
||||||
.on("click", BDFDB.dotCN.switchinner, () => {this.updateSettings(settingspanel);})
|
.on("click", BDFDB.dotCN.switchinner, () => {this.updateSettings(settingspanel);})
|
||||||
.on("click", ".reset-button", () => {this.resetAll();});
|
.on("click", ".reset-button", () => {
|
||||||
|
if (confirm("Are you sure you want to reset all channels?")) {
|
||||||
|
BDFDB.removeAllData(this, "channels");
|
||||||
|
this.forceAllUpdates();
|
||||||
|
}
|
||||||
|
});
|
||||||
return settingspanel;
|
return settingspanel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,74 +151,18 @@ class EditChannels {
|
||||||
if (typeof BDFDB === "object") {
|
if (typeof BDFDB === "object") {
|
||||||
BDFDB.loadMessage(this);
|
BDFDB.loadMessage(this);
|
||||||
|
|
||||||
|
for (let type in this.moduleTypes) {
|
||||||
|
let module = BDFDB.WebModules.findByName(type);
|
||||||
|
if (module && module.prototype) BDFDB.WebModules.patch(module.prototype, this.moduleTypes[type], this, {after: (e) => {this.initiateProcess(e.thisObject, type);}});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.UserUtils = BDFDB.WebModules.findByProperties("getUsers","getUser");
|
||||||
|
this.ChannelUtils = BDFDB.WebModules.findByProperties("getChannels","getChannel");
|
||||||
|
this.CurrentChannelUtils = BDFDB.WebModules.findByProperties("getChannels","getDefaultChannel");
|
||||||
this.LastGuildStore = BDFDB.WebModules.findByProperties("getLastSelectedGuildId");
|
this.LastGuildStore = BDFDB.WebModules.findByProperties("getLastSelectedGuildId");
|
||||||
|
this.LastChannelStore = BDFDB.WebModules.findByProperties("getLastSelectedChannelId");
|
||||||
|
|
||||||
var observer = null;
|
this.forceAllUpdates();
|
||||||
|
|
||||||
observer = new MutationObserver((changes, _) => {
|
|
||||||
changes.forEach(
|
|
||||||
(change, i) => {
|
|
||||||
if (change.attributeName == "class") {
|
|
||||||
var node = change.target;
|
|
||||||
if (node.className && node.className.length > -1 && node.className.includes("wrapper") && $("[custom-editchannels]").has(node)[0]) {
|
|
||||||
let info = BDFDB.getKeyInformation({"node":node, "key":"channel"});
|
|
||||||
if (info) this.loadChannel(BDFDB.getDivOfChannel(info.id));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (change.addedNodes) {
|
|
||||||
change.addedNodes.forEach((node) => {
|
|
||||||
if (node && node.classList && (node.classList.contains(BDFDB.disCN.channelcontainerdefault) || node.classList.contains(BDFDB.disCN.categorycontainerdefault))) {
|
|
||||||
let info = BDFDB.getKeyInformation({"node":node, "key":"channel"});
|
|
||||||
if (info) this.loadChannel(BDFDB.getDivOfChannel(info.id));
|
|
||||||
}
|
|
||||||
if (node.className && node.className.length > -1 && node.className.includes("container-")) {
|
|
||||||
for (let channel of node.querySelectorAll(BDFDB.dotCNC.channelcontainerdefault + BDFDB.dotCN.categorycontainerdefault)) {
|
|
||||||
let info = BDFDB.getKeyInformation({"node":channel, "key":"channel"});
|
|
||||||
if (info) this.loadChannel(BDFDB.getDivOfChannel(info.id));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
BDFDB.addObserver(this, BDFDB.dotCN.channels, {name:"channelListObserver",instance:observer}, {childList: true, attributes:true, subtree: true});
|
|
||||||
|
|
||||||
observer = new MutationObserver((changes, _) => {
|
|
||||||
changes.forEach(
|
|
||||||
(change, i) => {
|
|
||||||
if (change.removedNodes) {
|
|
||||||
change.removedNodes.forEach((node) => {
|
|
||||||
if (this.updateChannels && node.tagName && node.getAttribute("layer-id") == "user-settings") {
|
|
||||||
this.resetAllChannels();
|
|
||||||
this.loadAllChannels();
|
|
||||||
this.updateChannels = false;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
BDFDB.addObserver(this, BDFDB.dotCN.layers, {name:"settingsWindowObserver",instance:observer}, {childList:true});
|
|
||||||
|
|
||||||
observer = new MutationObserver((changes, _) => {
|
|
||||||
changes.forEach(
|
|
||||||
(change, i) => {
|
|
||||||
if (change.addedNodes) {
|
|
||||||
change.addedNodes.forEach((node) => {
|
|
||||||
if (node && node.nodeType == 1 && node.className.includes(BDFDB.disCN.contextmenu)) {
|
|
||||||
this.onContextMenu(node);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
);
|
|
||||||
});
|
|
||||||
BDFDB.addObserver(this, BDFDB.dotCN.appmount, {name:"channelContextObserver",instance:observer}, {childList: true});
|
|
||||||
|
|
||||||
this.loadAllChannels();
|
|
||||||
|
|
||||||
this.changeChannelHeader();
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
console.error(this.getName() + ": Fatal Error: Could not load BD functions!");
|
console.error(this.getName() + ": Fatal Error: Could not load BD functions!");
|
||||||
|
@ -216,25 +171,15 @@ class EditChannels {
|
||||||
|
|
||||||
stop () {
|
stop () {
|
||||||
if (typeof BDFDB === "object") {
|
if (typeof BDFDB === "object") {
|
||||||
this.resetAllChannels();
|
let data = BDFDB.loadAllData(this, "channels");
|
||||||
|
BDFDB.removeAllData(this, "channels");
|
||||||
|
this.forceAllUpdates();
|
||||||
|
BDFDB.saveAllData(data, this, "channels");
|
||||||
|
|
||||||
BDFDB.unloadMessage(this);
|
BDFDB.unloadMessage(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
onSwitch () {
|
|
||||||
if (typeof BDFDB === "object") {
|
|
||||||
var channelHeader = document.querySelector(BDFDB.dotCN.channelheadertitletext + "[custom-editchannelsheader]");
|
|
||||||
if (channelHeader) {
|
|
||||||
channelHeader.removeAttribute("custom-editchannelsheader");
|
|
||||||
var channel = channelHeader.querySelector(BDFDB.dotCN.channelheaderchannelname + BDFDB.dotCN.channelheaderprivate);
|
|
||||||
if (channel) this.uncolorChannel(channel);
|
|
||||||
}
|
|
||||||
this.loadAllChannels();
|
|
||||||
setImmediate(() => {this.changeChannelHeader();}); //setImmediate so EditChannels sets the color after EditUsers set it back to white
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// begin of own functions
|
// begin of own functions
|
||||||
|
|
||||||
|
@ -247,14 +192,6 @@ class EditChannels {
|
||||||
this.updateChannels = true;
|
this.updateChannels = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
resetAll () {
|
|
||||||
if (confirm("Are you sure you want to reset all channels?")) {
|
|
||||||
BDFDB.removeAllData(this, "channels");
|
|
||||||
|
|
||||||
this.resetAllChannels();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
changeLanguageStrings () {
|
changeLanguageStrings () {
|
||||||
this.channelContextEntryMarkup = this.channelContextEntryMarkup.replace("REPLACE_context_localchannelsettings_text", this.labels.context_localchannelsettings_text);
|
this.channelContextEntryMarkup = this.channelContextEntryMarkup.replace("REPLACE_context_localchannelsettings_text", this.labels.context_localchannelsettings_text);
|
||||||
|
|
||||||
|
@ -267,39 +204,29 @@ class EditChannels {
|
||||||
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_btn_save_text", this.labels.btn_save_text);
|
this.channelSettingsModalMarkup = this.channelSettingsModalMarkup.replace("REPLACE_btn_save_text", this.labels.btn_save_text);
|
||||||
}
|
}
|
||||||
|
|
||||||
onContextMenu (context) {
|
onChannelContextMenu (instance, menu) {
|
||||||
if (!context || !context.tagName || !context.parentElement || context.querySelector(".localchannelsettings-item")) return;
|
if (instance.props && instance.props.channel && !menu.querySelector(".localchannelsettings-item")) {
|
||||||
var info = BDFDB.getKeyInformation({"node":context, "key":"channel"});
|
$(menu).append(this.channelContextEntryMarkup)
|
||||||
if (info && BDFDB.getKeyInformation({"node":context, "key":"displayName", "value":"ChannelDeleteGroup"})) {
|
|
||||||
$(context).append(this.channelContextEntryMarkup)
|
|
||||||
.on("mouseenter", ".localchannelsettings-item", (e) => {
|
.on("mouseenter", ".localchannelsettings-item", (e) => {
|
||||||
this.createContextSubMenu(info, e, context);
|
|
||||||
});
|
|
||||||
|
|
||||||
BDFDB.updateContextPosition(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
createContextSubMenu (info, e, context) {
|
|
||||||
var channelContextSubMenu = $(this.channelContextSubMenuMarkup);
|
var channelContextSubMenu = $(this.channelContextSubMenuMarkup);
|
||||||
|
|
||||||
channelContextSubMenu
|
channelContextSubMenu
|
||||||
.on("click", ".channelsettings-item", () => {
|
.on("click", ".channelsettings-item", () => {
|
||||||
$(context).hide();
|
$(menu).hide();
|
||||||
this.showChannelSettings(info);
|
this.showChannelSettings(instance.props.channel);
|
||||||
});
|
});
|
||||||
|
if (BDFDB.loadData(instance.props.channel.id, this, "channels")) {
|
||||||
if (BDFDB.loadData(info.id, this, "channels")) {
|
|
||||||
channelContextSubMenu
|
channelContextSubMenu
|
||||||
.find(".resetsettings-item")
|
.find(".resetsettings-item")
|
||||||
.removeClass(BDFDB.disCN.contextmenuitemdisabled)
|
.removeClass(BDFDB.disCN.contextmenuitemdisabled)
|
||||||
.on("click", () => {
|
.on("click", () => {
|
||||||
$(context).hide();
|
$(menu).hide();
|
||||||
this.removeChannelData(info);
|
BDFDB.removeData(instance.props.channel.id, this, "channels");
|
||||||
|
this.forceAllUpdates();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
BDFDB.appendSubMenu(e.currentTarget, channelContextSubMenu);
|
BDFDB.appendSubMenu(e.currentTarget, channelContextSubMenu);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
showChannelSettings (info) {
|
showChannelSettings (info) {
|
||||||
|
@ -332,175 +259,231 @@ class EditChannels {
|
||||||
if (color[0] < 30 && color[1] < 30 && color[2] < 30) BDFDB.colorCHANGE(color, 30);
|
if (color[0] < 30 && color[1] < 30 && color[2] < 30) BDFDB.colorCHANGE(color, 30);
|
||||||
else if (color[0] > 225 && color[1] > 225 && color[2] > 225) BDFDB.colorCHANGE(color, -30);
|
else if (color[0] > 225 && color[1] > 225 && color[2] > 225) BDFDB.colorCHANGE(color, -30);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (name == null && color == null) {
|
if (name == null && color == null) {
|
||||||
this.removeChannelData(info);
|
BDFDB.removeData(info.id, this, "channels");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
BDFDB.saveData(info.id, {name,color}, this, "channels");
|
BDFDB.saveData(info.id, {name,color}, this, "channels");
|
||||||
this.loadChannel(channelObj);
|
|
||||||
this.changeChannelHeader();
|
|
||||||
}
|
}
|
||||||
|
this.forceAllUpdates();
|
||||||
});
|
});
|
||||||
|
|
||||||
channelSettingsModal.find("#input-channelname").focus();
|
channelSettingsModal.find("#input-channelname").focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
removeChannelData (info) {
|
initiateProcess (instance, type) {
|
||||||
this.resetChannel(BDFDB.getDivOfChannel(info.id));
|
type = type.replace(/[^A-z]/g,"");
|
||||||
|
type = type[0].toUpperCase() + type.slice(1);
|
||||||
BDFDB.removeData(info.id, this, "channels");
|
if (typeof this["process" + type] == "function") {
|
||||||
|
let wrapper = BDFDB.React.findDOMNodeSafe(instance);
|
||||||
this.changeChannelHeader();
|
if (wrapper) this["process" + type](instance, wrapper);
|
||||||
|
else setImmediate(() => {
|
||||||
|
this["process" + type](instance, BDFDB.React.findDOMNodeSafe(instance));
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
resetChannel (channelObj) {
|
processChannelTextArea (instance, wrapper) {
|
||||||
if (!channelObj || !channelObj.div) return;
|
if (!wrapper) return;
|
||||||
|
if (instance.props && instance.props.type == "normal" && instance.props.channel && instance.props.channel.type == 0) {
|
||||||
var channel = channelObj.div.querySelector(BDFDB.dotCNC.channelname + BDFDB.dotCN.categorycolortransition);
|
let channel = instance.props.channel;
|
||||||
|
let data = BDFDB.loadData(channel.id, this, "channels") || {};
|
||||||
if (channel && channel.EditChannelsObserver && typeof channel.EditChannelsObserver.disconnect == "function") channel.EditChannelsObserver.disconnect();
|
wrapper.querySelector("textarea").setAttribute("placeholder", BDFDB.LanguageStrings.TEXTAREA_PLACEHOLDER.replace("{{channel}}", "#" + (data.name || channel.name)));
|
||||||
|
}
|
||||||
channelObj.div.removeAttribute("custom-editchannels");
|
|
||||||
this.uncolorChannel(channel);
|
|
||||||
|
|
||||||
BDFDB.setInnerText(channel, channelObj.name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
loadChannel (channelObj) {
|
processAuditLog (instance, wrapper) {
|
||||||
if (!channelObj || !channelObj.div) return;
|
if (!wrapper) return;
|
||||||
|
if (instance.props && instance.props.log && instance.props.log.options && instance.props.log.options.channel) {
|
||||||
|
let hooks = wrapper.querySelectorAll(BDFDB.dotCN.flexchild + " > span:not(" + BDFDB.dotCN.auditloguserhook + ")");
|
||||||
|
if (hooks.length > 0) this.changeChannel2(instance.props.log.options.channel, hooks[0].firstChild);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var channel = channelObj.div.querySelector(BDFDB.dotCNC.channelname + BDFDB.dotCN.categorycolortransition);
|
processChannelCategoryItem (instance, wrapper) {
|
||||||
|
if (!wrapper) return;
|
||||||
|
if (instance.props && instance.props.channel) {
|
||||||
|
this.changeChannel(instance.props.channel, wrapper.querySelector(BDFDB.dotCN.categorycolortransition));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (channel && channel.EditChannelsObserver && typeof channel.EditChannelsObserver.disconnect == "function") channel.EditChannelsObserver.disconnect();
|
processChannelItem (instance, wrapper) {
|
||||||
|
if (!wrapper) return;
|
||||||
|
if (instance.props && instance.props.channel) {
|
||||||
|
this.changeChannel(instance.props.channel, wrapper.querySelector(BDFDB.dotCN.channelname));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var data = BDFDB.loadData(channelObj.id, this, "channels");
|
processHeaderBar (instance, wrapper) {
|
||||||
if (data) {
|
let fiber = instance._reactInternalFiber;
|
||||||
var name = data.name ? data.name : channelObj.name;
|
if (fiber.return && fiber.return.memoizedProps && fiber.return.memoizedProps.channelId) {
|
||||||
var color = data.color ? this.chooseColor(channel, data.color) : "";
|
let channelname = wrapper.querySelector(BDFDB.dotCN.channelheaderchannelname);
|
||||||
|
if (channelname) {
|
||||||
|
let channel = this.ChannelUtils.getChannel(fiber.return.memoizedProps.channelId);
|
||||||
|
if (channel) {
|
||||||
|
if (channel.type == 0) this.changeChannel(channel, wrapper.querySelector(BDFDB.dotCN.channelheaderchannelname));
|
||||||
|
else {
|
||||||
|
if (channel.type == 1) channel = this.UserUtils.getUser(channel.recipients[0]) || channel;
|
||||||
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
||||||
|
channelname.style.removeProperty("color");
|
||||||
|
channelname.style.removeProperty("background");
|
||||||
|
BDFDB.setInnerText(channelname, channel.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
this.colorChannel(channel, color);
|
processClickable (instance, wrapper) {
|
||||||
|
if (!wrapper || !instance.props || !instance.props.className) return;
|
||||||
|
else if (instance.props.tag == "span" && instance.props.className.indexOf(BDFDB.disCN.mentionwrapper) > -1 && instance.props.className.indexOf(BDFDB.disCN.mention) == -1) {
|
||||||
|
let fiber = instance._reactInternalFiber;
|
||||||
|
if (fiber.memoizedProps && fiber.memoizedProps.children && typeof fiber.memoizedProps.children[0] == "string") {
|
||||||
|
let channelname = fiber.memoizedProps.children[0].slice(1);
|
||||||
|
let categoryname = fiber.return && fiber.return.return && fiber.return.return.type && fiber.return.return.type.displayName == "Tooltip" ? fiber.return.return.memoizedProps.text : null;
|
||||||
|
for (let channel of this.CurrentChannelUtils.getChannels(this.LastGuildStore.getGuildId())[0]) {
|
||||||
|
if (channelname == channel.channel.name) {
|
||||||
|
let category = categoryname ? this.ChannelUtils.getChannel(channel.channel.parent_id) : null;
|
||||||
|
if (!category || category && categoryname == category.name) {
|
||||||
|
this.changeMention(channel.channel, wrapper, category || {});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (instance.props.tag == "div" && instance.props.className.indexOf(BDFDB.disCN.quickswitchresult) > -1) {
|
||||||
|
let fiber = instance._reactInternalFiber;
|
||||||
|
if (fiber.return && fiber.return.memoizedProps && fiber.return.memoizedProps.result && fiber.return.memoizedProps.result.type == "TEXT_CHANNEL") {
|
||||||
|
this.changeChannel(fiber.return.memoizedProps.result.record, wrapper.querySelector(BDFDB.dotCN.quickswitchresultmatch));
|
||||||
|
if (fiber.return.memoizedProps.result.record.parent_id) {
|
||||||
|
this.changeChannel(this.ChannelUtils.getChannel(fiber.return.memoizedProps.result.record.parent_id), wrapper.querySelector(BDFDB.dotCN.quickswitchresultnote));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (instance.props.tag == "div" && instance.props.className.indexOf(BDFDB.disCN.autocompleterow) > -1) {
|
||||||
|
let fiber = instance._reactInternalFiber;
|
||||||
|
if (fiber.return && fiber.return.memoizedProps && fiber.return.memoizedProps.channel) {
|
||||||
|
this.changeChannel(fiber.return.memoizedProps.channel, wrapper.querySelector(BDFDB.dotCN.marginleft4));
|
||||||
|
if (fiber.return.memoizedProps.category) this.changeChannel(fiber.return.memoizedProps.category, wrapper.querySelector(BDFDB.dotCN.autocompletedescription));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
changeChannel (info, channelname) {
|
||||||
|
if (!info || !channelname || !channelname.parentElement) return;
|
||||||
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
||||||
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
||||||
|
let settings = BDFDB.getAllData(this, "settings");
|
||||||
|
let color = this.chooseColor(channelname, data.color);
|
||||||
|
channelname.style.setProperty("color", color, "important");
|
||||||
|
BDFDB.setInnerText(channelname, data.name || info.name);
|
||||||
|
let iconparent = channelname.classList && channelname.classList.contains(BDFDB.disCN.quickswitchresultmatch) ? channelname.parentElement.parentElement : channelname.parentElement;
|
||||||
|
if (channelname.classList && !channelname.classList.contains(BDFDB.disCN.autocompletedescription)) {
|
||||||
|
iconparent.querySelectorAll('svg [stroke]:not([stroke="none"]').forEach(icon => {
|
||||||
|
if (!icon.getAttribute("oldstroke")) icon.setAttribute("oldstroke", icon.getAttribute("stroke"));
|
||||||
|
icon.setAttribute("stroke", color && settings.changeChannelIcon ? color : icon.getAttribute("oldstroke"), "important");
|
||||||
|
icon.style.setProperty("stroke", color && settings.changeChannelIcon ? color : icon.getAttribute("oldstroke"), "important");
|
||||||
|
});
|
||||||
|
iconparent.querySelectorAll('svg [fill]:not([fill="none"]').forEach(icon => {
|
||||||
|
if (!icon.getAttribute("oldfill")) icon.setAttribute("oldfill", icon.getAttribute("fill"));
|
||||||
|
icon.setAttribute("fill", color && settings.changeChannelIcon ? color : icon.getAttribute("oldfill"), "important");
|
||||||
|
icon.style.setProperty("fill", color && settings.changeChannelIcon ? color : icon.getAttribute("oldfill"), "important");
|
||||||
|
});
|
||||||
|
let unread = iconparent.querySelector(BDFDB.dotCN.channelunread);
|
||||||
|
if (unread) unread.style.setProperty("background-color", color && settings.changeUnreadIndicator ? color : "currentColor", "important");
|
||||||
|
}
|
||||||
if (color) {
|
if (color) {
|
||||||
channel.EditChannelsObserver = new MutationObserver((changes, _) => {
|
channelname.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
||||||
changes.forEach(
|
changes.forEach(
|
||||||
(change, i) => {
|
(change, i) => {
|
||||||
if (change.type == "childList" && change.addedNodes.length && change.target.tagName && (change.target.tagName == "SVG" || change.target.querySelector("svg")) || change.type == "attributes" && change.attributeName == "class" && change.target.className.length && change.target.className.indexOf("name") > -1) {
|
if (change.type == "childList" && change.addedNodes.length && change.target.tagName && (change.target.tagName == "SVG" || change.target.querySelector("svg")) || change.type == "attributes" && change.attributeName == "class" && change.target.className.length && change.target.className.indexOf("name") > -1) {
|
||||||
this.colorChannel(channel, this.chooseColor(channel, data.color));
|
channelname.EditChannelsChangeObserver.disconnect();
|
||||||
|
this.changeChannel(info, channelname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
channel.EditChannelsObserver.observe(channel.parentElement, {attributes:true, childList:true, subtree:true});
|
channelname.EditChannelsChangeObserver.observe(iconparent, {attributes:true, childList:true, subtree:true});
|
||||||
}
|
|
||||||
|
|
||||||
BDFDB.setInnerText(channel, name);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
loadAllChannels () {
|
changeChannel2 (info, channelname) {
|
||||||
for (let channelObj of BDFDB.readChannelList()) {
|
if (!info || !channelname || !channelname.parentElement) return;
|
||||||
this.loadChannel(channelObj);
|
if (channelname.EditChannelsChangeObserver && typeof channelname.EditChannelsChangeObserver.disconnect == "function") channelname.EditChannelsChangeObserver.disconnect();
|
||||||
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
||||||
|
let color = this.chooseColor(channelname, data.color);
|
||||||
|
console.log();
|
||||||
|
channelname.style.setProperty("color", color, "important");
|
||||||
|
BDFDB.setInnerText(channelname, "#" + (data.name || info.name));
|
||||||
|
if (color) {
|
||||||
|
channelname.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
||||||
|
changes.forEach(
|
||||||
|
(change, i) => {
|
||||||
|
if (change.type == "childList" && change.addedNodes.length && change.target.tagName && (change.target.tagName == "SVG" || change.target.querySelector("svg")) || change.type == "attributes" && change.attributeName == "class" && change.target.className.length && change.target.className.indexOf("name") > -1) {
|
||||||
|
channelname.EditChannelsChangeObserver.disconnect();
|
||||||
|
this.changeChannel2(info, channelname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
);
|
||||||
changeChannelHeader () {
|
|
||||||
if (BDFDB.getData("changeInChannelHeader", this, "settings") && this.LastGuildStore.getGuildId()) {
|
|
||||||
var channelHeader = document.querySelector(BDFDB.dotCNS.channelheadertitle + BDFDB.dotCN.channelheadertitletext);
|
|
||||||
if (!channelHeader) return;
|
|
||||||
var channel = channelHeader.querySelector(BDFDB.dotCN.channelheaderchannelname);
|
|
||||||
if (!channel) return;
|
|
||||||
var info = BDFDB.getKeyInformation({"node":channelHeader,"key":"channel"});
|
|
||||||
if (info) {
|
|
||||||
var data = BDFDB.loadData(info.id, this, "channels");
|
|
||||||
var name = data && data.name ? data.name : info.name;
|
|
||||||
var color = data && data.color ? BDFDB.colorCHANGE(data.color, 0.5, "RGB") : "";
|
|
||||||
|
|
||||||
if (data && (data.name || data.color)) {
|
|
||||||
channelHeader.setAttribute("custom-editchannelsheader", true);
|
|
||||||
this.colorChannel(channel, color);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
channelHeader.removeAttribute("custom-editchannelsheader");
|
|
||||||
this.uncolorChannel(channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
BDFDB.setInnerText(channel, name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
resetAllChannels () {
|
|
||||||
document.querySelectorAll("[custom-editchannels]").forEach(channelDiv => {
|
|
||||||
var info = BDFDB.getKeyInformation({"node":channelDiv, "key":"channel"});
|
|
||||||
if (info) this.resetChannel({div:channelDiv,info});
|
|
||||||
});
|
});
|
||||||
|
channelname.EditChannelsChangeObserver.observe(channelname.parentElement, {attributes:true, childList:true, subtree:true});
|
||||||
var channelHeader = document.querySelector("[custom-editchannelsheader]");
|
|
||||||
if (channelHeader) {
|
|
||||||
var info = BDFDB.getKeyInformation({"node":channelHeader, "key":"channel"});
|
|
||||||
if (info) {
|
|
||||||
var channel = channelHeader.querySelector(BDFDB.dotCN.channelheaderchannelname);
|
|
||||||
|
|
||||||
channelHeader.removeAttribute("custom-editchannelsheader");
|
|
||||||
channel.style.removeProperty("color");
|
|
||||||
|
|
||||||
BDFDB.setInnerText(channel, info.name);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
colorChannel (channel, color) {
|
changeMention (info, mention, categoryinfo) {
|
||||||
if (!channel) return;
|
if (!info || !mention || !mention.parentElement) return;
|
||||||
var settings = BDFDB.getAllData(this, "settings");
|
if (mention.EditChannelsChangeObserver && typeof mention.EditChannelsChangeObserver.disconnect == "function") mention.EditChannelsChangeObserver.disconnect();
|
||||||
channel.style.setProperty("color", color, "important");
|
let data = BDFDB.loadData(info.id, this, "channels") || {};
|
||||||
if (settings.changeChannelIcon) {
|
let color = BDFDB.colorCONVERT(data.color, "RGBCOMP");
|
||||||
channel.parentElement.querySelectorAll("svg [stroke='currentColor'], svg [stroke='#ffffff'], svg [oldstroke]").forEach(icon => {
|
BDFDB.setInnerText(mention, "#" + (data.name || info.name));
|
||||||
icon.setAttribute("oldstroke", icon.getAttribute("oldstroke") || icon.getAttribute("stroke"));
|
if (mention.EditChannelsHovered) colorHover();
|
||||||
icon.setAttribute("stroke", color, "important");
|
else colorDefault();
|
||||||
|
$(mention)
|
||||||
|
.off("mouseenter." + this.getName()).off("mouseleave." + this.getName())
|
||||||
|
.on("mouseenter." + this.getName(), (e) => {
|
||||||
|
mention.EditChannelsHovered = true;
|
||||||
|
colorHover();
|
||||||
|
let categorydata = BDFDB.loadData(categoryinfo.id, this, "channels") || {};
|
||||||
|
if (categorydata.name) BDFDB.createTooltip(categorydata.name, mention, {type:"top",selector:"EditChannels-tooltip",css:`body ${BDFDB.dotCN.tooltip}:not(.EditChannels-tooltip) {display: none !important;}`});
|
||||||
|
})
|
||||||
|
.on("mouseleave." + this.getName(), (e) => {
|
||||||
|
mention.EditChannelsHovered = false;
|
||||||
|
colorDefault();
|
||||||
});
|
});
|
||||||
channel.parentElement.querySelectorAll("svg [fill='currentColor'], svg [fill='#ffffff'], svg [oldfill]").forEach(icon => {
|
mention.EditChannelsChangeObserver = new MutationObserver((changes, _) => {
|
||||||
icon.setAttribute("oldfill", icon.getAttribute("oldfill") || icon.getAttribute("fill"));
|
mention.EditChannelsChangeObserver.disconnect();
|
||||||
icon.setAttribute("fill", color, "important");
|
this.changeMention(info, mention, categoryinfo);
|
||||||
});
|
});
|
||||||
|
mention.EditChannelsChangeObserver.observe(mention, {attributes:true});
|
||||||
|
function colorDefault() {
|
||||||
|
mention.style.setProperty("color", color ? "rgb(" + color[0] + "," + color[1] + "," + color[2] + ")" : null, "important");
|
||||||
|
mention.style.setProperty("background", color ? "rgba(" + color[0] + "," + color[1] + "," + color[2] + ",.1)" : null, "important");
|
||||||
}
|
}
|
||||||
if (settings.changeUnreadIndicator) {
|
function colorHover() {
|
||||||
var unread = channel.parentElement.querySelector(BDFDB.dotCN.channelunread);
|
mention.style.setProperty("color", color ? "#FFFFFF" : null, "important");
|
||||||
if (unread) unread.style.setProperty("background-color", color, "important");
|
mention.style.setProperty("background", color ? "rgba(" + color[0] + "," + color[1] + "," + color[2] + ",.7)" : null, "important");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uncolorChannel (channel) {
|
chooseColor (channelname, color) {
|
||||||
if (!channel) return;
|
if (color && channelname) {
|
||||||
channel.style.removeProperty("color");
|
let classname = channelname.className ? channelname.className.toLowerCase() : "";
|
||||||
channel.style.removeProperty("background-color");
|
if (classname.indexOf("muted") > -1 || classname.indexOf("locked") > -1) color = BDFDB.colorCHANGE(color, -0.5);
|
||||||
channel.parentElement.querySelectorAll("svg [oldstroke]").forEach(icon => {
|
else if (classname.indexOf("selected") > -1 || classname.indexOf("hovered") > -1 || classname.indexOf("unread") > -1) color = BDFDB.colorCHANGE(color, 0.5);
|
||||||
icon.setAttribute("stroke", icon.getAttribute("oldstroke"));
|
|
||||||
icon.removeAttribute("oldstroke");
|
|
||||||
});
|
|
||||||
channel.parentElement.querySelectorAll("svg [oldfill]").forEach(icon => {
|
|
||||||
icon.setAttribute("fill", icon.getAttribute("oldfill"));
|
|
||||||
icon.removeAttribute("oldfill");
|
|
||||||
});
|
|
||||||
var unread = channel.parentElement.querySelector(BDFDB.dotCN.channelunread);
|
|
||||||
if (unread) unread.style.removeProperty("background-color");
|
|
||||||
}
|
|
||||||
|
|
||||||
chooseColor (channel, color) {
|
|
||||||
if (color && channel && channel.className) {
|
|
||||||
if (channel.className.indexOf("nameMuted") > -1 || channel.className.indexOf("nameLocked") > -1) {
|
|
||||||
color = BDFDB.colorCHANGE(color, -0.5);
|
|
||||||
}
|
|
||||||
if (channel.className.indexOf("nameDefault") > -1) {
|
|
||||||
color = color;
|
|
||||||
}
|
|
||||||
if (channel.className.indexOf("nameSelected") > -1 || channel.className.indexOf("nameHovered") > -1 || channel.className.indexOf("nameUnread") > -1) {
|
|
||||||
color = BDFDB.colorCHANGE(color, 0.5);
|
|
||||||
}
|
|
||||||
return BDFDB.colorCONVERT(color, "RGB");
|
return BDFDB.colorCONVERT(color, "RGB");
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
forceAllUpdates () {
|
||||||
|
let app = document.querySelector(BDFDB.dotCN.app);
|
||||||
|
if (app) {
|
||||||
|
let ins = BDFDB.getOwnerInstance({node:app, name:Object.keys(this.moduleTypes), all:true, noCopies:true, group:true, depth:99999999, time:99999999});
|
||||||
|
for (let type in ins) for (let i in ins[type]) this.initiateProcess(ins[type][i], type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
setLabelsByLanguage () {
|
setLabelsByLanguage () {
|
||||||
switch (BDFDB.getDiscordLanguage().id) {
|
switch (BDFDB.getDiscordLanguage().id) {
|
||||||
case "hr": //croatian
|
case "hr": //croatian
|
||||||
|
|
Loading…
Reference in New Issue