RemoveNicknames now uses patching instead of observing

This commit is contained in:
Mirco Wittrien 2019-01-02 12:52:40 +01:00
parent ace409df4b
commit 1d5460393e
3 changed files with 82 additions and 153 deletions

File diff suppressed because one or more lines are too long

View File

@ -289,7 +289,7 @@ class EditUsers {
onUserContextMenu (instance, menu) {
if (instance.props && instance.props.user && !menu.querySelector(".localusersettings-item")) {
$(menu).append(this.userContextEntryMarkup)
.on("mouseenter", ".localusersettings-item", (e) => {
.on("mouseenter." + this.getName(), ".localusersettings-item", (e) => {
var userContextSubMenu = $(this.userContextSubMenuMarkup);
userContextSubMenu
.on("click", ".usersettings-item", () => {
@ -734,7 +734,8 @@ class EditUsers {
let data = this.getUserData(info.id, mention);
let member = this.MemberUtils.getMember(this.LastGuildStore.getGuildId(), info.id) || {};
let color1 = BDFDB.colorCONVERT(data.color1 || (BDFDB.isPluginEnabled("BetterRoleColors") ? member.colorString : null), "RGBCOMP");
BDFDB.setInnerText(mention, "@" + (data.name || member.nick || info.username));
let name = BDFDB.isPluginEnabled("RemoveNicknames") ? bdplugins.RemoveNicknames.plugin.getNewName(info) : data.name || member.nick || info.username;
BDFDB.setInnerText(mention, "@" + name);
if (mention.EditUsersHovered) colorHover();
else colorDefault();
$(mention)

View File

@ -2,6 +2,14 @@
class RemoveNicknames {
initConstructor () {
this.patchModules = {
"NameTag":"componentDidMount",
"FluxContainer(TypingUsers)":"componentDidUpdate",
"Popout":"componentDidMount",
"Clickable":"componentDidMount",
"StandardSidebarView":"componentWillUnmount"
};
this.defaults = {
settings: {
replaceOwn: {value:false, description:"Replace your own name:"},
@ -15,7 +23,7 @@ class RemoveNicknames {
getDescription () {return "Replace all nicknames with the actual accountnames.";}
getVersion () {return "1.1.1";}
getVersion () {return "1.1.2";}
getAuthor () {return "DevilBro";}
@ -59,73 +67,14 @@ class RemoveNicknames {
if (typeof BDFDB === "object") {
BDFDB.loadMessage(this);
this.reseting = false;
this.UserStore = BDFDB.WebModules.findByProperties("getUsers", "getUser");
this.MemberPerms = BDFDB.WebModules.findByProperties("getNicknames", "getNick");
this.LastGuildStore = BDFDB.WebModules.findByProperties("getLastSelectedGuildId");
this.LastChannelStore = BDFDB.WebModules.findByProperties("getLastSelectedChannelId");
this.MemberStore = BDFDB.WebModules.findByProperties("getNicknames", "getNick");
var observer = null;
observer = new MutationObserver((changes, _) => {
changes.forEach(
(change, i) => {
if (change.addedNodes) {
change.addedNodes.forEach((node) => {
if (node && node.tagName && node.querySelector(BDFDB.dotCN.voiceuserdefault)) {
this.loadUser(node.querySelector(BDFDB.dotCN.voiceuserdefault).parentElement, "voice", false);
}
});
}
}
);
});
BDFDB.addObserver(this, BDFDB.dotCN.channels, {name:"channelListObserver",instance:observer}, {childList: true, subtree: true});
observer = new MutationObserver((changes, _) => {
changes.forEach(
(change, i) => {
if (change.addedNodes) {
change.addedNodes.forEach((node) => {
if (node && node.tagName && node.querySelector(BDFDB.dotCN.memberusername)) {
this.loadUser(node, "list", false);
}
});
}
}
);
});
BDFDB.addObserver(this, BDFDB.dotCN.members, {name:"userListObserver",instance:observer}, {childList:true});
observer = new MutationObserver((changes, _) => {
changes.forEach(
(change, i) => {
if (change.addedNodes) {
change.addedNodes.forEach((node) => {
if (node && node.tagName && node.querySelector(BDFDB.dotCN.messageusername)) {
this.loadUser(node, "chat", BDFDB.getDiscordTheme() == "compact");
}
});
}
}
);
});
BDFDB.addObserver(this, BDFDB.dotCN.messages, {name:"chatWindowObserver",instance:observer}, {childList:true, subtree:true});
observer = new MutationObserver((changes, _) => {
changes.forEach(
(change, i) => {
if (change.removedNodes) {
change.removedNodes.forEach((node) => {
if (node && node.tagName && node.getAttribute("layer-id") == "user-settings") {
this.resetAllUsers();
this.loadAllUsers();
}
});
}
}
);
});
BDFDB.addObserver(this, BDFDB.dotCN.layers, {name:"settingsWindowObserver",instance:observer}, {childList:true});
this.loadAllUsers();
BDFDB.WebModules.forceAllUpdates(this);
}
else {
console.error(this.getName() + ": Fatal Error: Could not load BD functions!");
@ -135,19 +84,13 @@ class RemoveNicknames {
stop () {
if (typeof BDFDB === "object") {
this.resetAllUsers();
this.reseting = true;
BDFDB.WebModules.forceAllUpdates(this);
BDFDB.unloadMessage(this);
}
}
onSwitch () {
if (typeof BDFDB === "object") {
BDFDB.addObserver(this, BDFDB.dotCN.members, {name:"userListObserver"}, {childList:true});
BDFDB.addObserver(this, BDFDB.dotCN.messages, {name:"chatWindowObserver"}, {childList:true, subtree:true});
setImmediate(() => {this.loadAllUsers();});
}
}
// begin of own functions
@ -157,90 +100,75 @@ class RemoveNicknames {
for (var input of settingspanel.querySelectorAll(BDFDB.dotCN.switchinner)) {
settings[input.value] = input.checked;
}
this.updateUsers = true;
BDFDB.saveAllData(settings, this, "settings");
}
loadAllUsers () {
for (let user of document.querySelectorAll(BDFDB.dotCN.member)) {
this.loadUser(user, "list", false);
}
for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcozy)) {
this.loadUser(messagegroup, "chat", false);
}
for (let messagegroup of document.querySelectorAll(BDFDB.dotCN.messagegroupcompact)) {
for (let message of messagegroup.querySelectorAll(BDFDB.dotCN.messagemarkup)) {
this.loadUser(message, "chat", true);
}
}
for (let user of document.querySelectorAll(BDFDB.dotCN.voiceuserdefault)) {
this.loadUser(user.parentElement, "voice", false);
getNewName (info) {
if (!info) return null;
let EditUsersData = BDFDB.isPluginEnabled("EditUsers") ? BDFDB.loadData(info.id, "EditUsers", "users") : null;
if (EditUsersData && EditUsersData.name) return EditUsersData.name;
let settings = BDFDB.getAllData(this, "settings");
let member = this.MemberStore.getMember(this.LastGuildStore.getGuildId(), info.id);
if (!member || !member.nick || info.id == BDFDB.myData.id && !settings.replaceOwn) return info.username;
if (this.reseting) return member.nick || info.username;
return settings.addNickname ? (settings.swapPositions ? (member.nick + " (" + info.username + ")") : (info.username + " (" + member.nick + ")")) : info.username;
}
processNameTag (instance, wrapper) {
let username = wrapper.parentElement.querySelector("." + (wrapper.classList && wrapper.classList.contains(BDFDB.disCN.userpopoutheadertagwithnickname) ? BDFDB.disCN.userpopoutheadernickname : instance.props.usernameClass).replace(/ /g, "."));
if (username) BDFDB.setInnerText(username, this.getNewName(instance.props.user));
}
processPopout (instance, wrapper) {
let fiber = instance._reactInternalFiber;
if (fiber.return && fiber.return.memoizedProps && fiber.return.memoizedProps.message) {
let username = wrapper.querySelector(BDFDB.dotCN.messageusername);
if (username) BDFDB.setInnerText(username, this.getNewName(fiber.return.memoizedProps.message.author));
}
}
loadUser (div, type, compact) {
if (!div || $(div).attr("removed-nickname") || !div.tagName) return;
let usernameWrapper = this.getNameWrapper(div);
if (!usernameWrapper) return;
$(div).data("compact", compact);
var info = this.getUserInfo(compact ? $(BDFDB.dotCN.messagegroup).has(div)[0] : div);
if (!info) return;
var settings = BDFDB.getAllData(this, "settings");
if (info.id == BDFDB.myData.id && !settings.replaceOwn) return;
var serverObj = BDFDB.getSelectedServer();
if (!serverObj) return;
var member = this.MemberPerms.getMember(serverObj.id, info.id);
if (!member || !member.nick) return;
var newname = settings.addNickname ? (settings.swapPositions ? (member.nick + " (" + info.username + ")") : (info.username + " (" + member.nick + ")")) : info.username;
BDFDB.setInnerText(usernameWrapper, newname);
div.setAttribute("removed-nickname", true);
}
resetAllUsers () {
document.querySelectorAll("[removed-nickname]").forEach((div) => {
let usernameWrapper = this.getNameWrapper(div);
if (!usernameWrapper) return;
var info = this.getUserInfo($(div).data("compact") ? $(BDFDB.dotCN.messagegroup).has(div)[0] : div);
if (!info) return;
var serverObj = BDFDB.getSelectedServer();
if (!serverObj) return;
var member = this.MemberPerms.getMember(serverObj.id, info.id);
if (!member || !member.nick) return;
BDFDB.setInnerText(usernameWrapper, member.nick);
div.removeAttribute("removed-nickname");
processFluxContainerTypingUsers (instance) {
let users = !instance.state.typingUsers ? [] : Object.keys(instance.state.typingUsers).filter(id => id != BDFDB.myData.id).filter(id => !this.RelationshipUtils.isBlocked(id)).map(id => this.UserUtils.getUser(id)).filter(id => id != null);
document.querySelectorAll(BDFDB.dotCNS.typing + "strong").forEach((username, i) => {
if (users[i]) if (username) BDFDB.setInnerText(username, this.getNewName(users[i]));
});
}
getNameWrapper (div) {
return div.querySelector(BDFDB.dotCNC.memberusername + BDFDB.dotCNC.voicenamedefault + BDFDB.dotCN.messageusername);
}
getUserInfo (div) {
var info = BDFDB.getKeyInformation({"node":div,"key":"user"});
if (!info) {
info = BDFDB.getKeyInformation({"node":div,"key":"message"});
if (info) info = info.author;
else {
info = BDFDB.getKeyInformation({"node":div,"key":"channel"});
if (info) info = {"id":info.recipients[0]};
else {
info = BDFDB.getKeyInformation({"node":$(BDFDB.dotCN.messagegroup).has(div)[0],"key":"message"});
if (info) info = info.author;
}
processClickable (instance, wrapper) {
if (!wrapper || !instance.props || !instance.props.className) return;
if (instance.props.tag == "a" && instance.props.className.indexOf(BDFDB.disCN.anchorunderlineonhover) > -1) {
if (wrapper.parentElement.classList.contains(BDFDB.disCN.messagesystemcontent)) {
let message = BDFDB.getKeyInformation({node:wrapper.parentElement, key:"message", up:true});
if (message) BDFDB.setInnerText(wrapper, this.getNewName(message.author));
}
}
return info && info.id ? this.UserStore.getUser(info.id) : null;
else if (instance.props.tag == "span" && instance.props.className.indexOf(BDFDB.disCN.mention) > -1) {
let fiber = instance._reactInternalFiber;
if (fiber.return && fiber.return.return && fiber.return.return.stateNode && fiber.return.return.stateNode.props && typeof fiber.return.return.stateNode.props.render == "function") {
if (wrapper) BDFDB.setInnerText(wrapper, "@" + this.getNewName(fiber.return.return.stateNode.props.render().props.user));
}
}
else if (instance.props.tag == "div" && instance.props.className.indexOf(BDFDB.disCN.voiceuser) > -1) {
let fiber = instance._reactInternalFiber;
if (fiber.return && fiber.return.memoizedProps && fiber.return.memoizedProps.user) {
let username = wrapper.querySelector(BDFDB.dotCN.voicename);
if (username) BDFDB.setInnerText(username, this.getNewName(fiber.return.memoizedProps.user));
}
}
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.user) {
let username = wrapper.querySelector(BDFDB.dotCN.marginleft8);
if (username) BDFDB.setInnerText(username, this.getNewName(fiber.return.memoizedProps.user));
}
}
}
processStandardSidebarView (instance, wrapper) {
if (this.updateUsers) {
this.updateUsers = false;
BDFDB.WebModules.forceAllUpdates(this);
}
}
}