Update EditUsers.plugin.js

This commit is contained in:
Mirco Wittrien 2020-06-28 09:41:02 +02:00
parent 9919454a80
commit 8b5e332278
1 changed files with 93 additions and 64 deletions

View File

@ -6,7 +6,7 @@ var EditUsers = (_ => {
return class EditUsers { return class EditUsers {
getName () {return "EditUsers";} getName () {return "EditUsers";}
getVersion () {return "3.8.7";} getVersion () {return "3.8.8";}
getAuthor () {return "DevilBro";} getAuthor () {return "DevilBro";}
@ -39,11 +39,13 @@ var EditUsers = (_ => {
QuickSwitchUserResult: "render", QuickSwitchUserResult: "render",
SearchPopoutComponent: "render", SearchPopoutComponent: "render",
IncomingCall: "render", IncomingCall: "render",
PrivateChannelCallParticipants: "render2", PrivateChannelCallParticipants: "render",
ChannelCall: "render2", ChannelCall: "render",
PictureInPictureVideo: "default",
UserSummaryItem: "render" UserSummaryItem: "render"
}, },
after: { after: {
ChannelCallHeader: "default",
AutocompleteUserResult: "render", AutocompleteUserResult: "render",
NameTag: "default", NameTag: "default",
UserPopout: "render", UserPopout: "render",
@ -60,7 +62,7 @@ var EditUsers = (_ => {
InviteModalUserRow: "default", InviteModalUserRow: "default",
TypingUsers: "render", TypingUsers: "render",
DirectMessage: "render", DirectMessage: "render",
RTCConnection: "render2", RTCConnection: "render",
PrivateChannel: "render", PrivateChannel: "render",
QuickSwitchUserResult: "render", QuickSwitchUserResult: "render",
IncomingCall: "render" IncomingCall: "render"
@ -70,7 +72,8 @@ var EditUsers = (_ => {
initConstructor () { initConstructor () {
this.css = ` this.css = `
${BDFDB.dotCNS.chat + BDFDB.dotCN.messageusername}:hover > span[style*="color"] { ${BDFDB.dotCNS.chat + BDFDB.dotCN.messageusername}:hover > span[style*="color"],
${BDFDB.dotCN.voicedetailschannel}:hover > span[style*="color"] {
text-decoration: underline; text-decoration: underline;
} }
${BDFDB.dotCN.dmchannel}:hover ${BDFDB.dotCN.namecontainername} span[style*="color"] { ${BDFDB.dotCN.dmchannel}:hover ${BDFDB.dotCN.namecontainername} span[style*="color"] {
@ -305,8 +308,8 @@ var EditUsers = (_ => {
if (data && data.name) e.instance.props.nick = data.name; if (data && data.name) e.instance.props.nick = data.name;
} }
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props:[["className", BDFDB.disCN.marginleft8]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props:[["className", BDFDB.disCN.marginleft8]]});
if (index > -1) this.changeUserColor(children[index], e.instance.props.user.id); if (userName) this.changeUserColor(userName, e.instance.props.user.id);
} }
} }
} }
@ -314,11 +317,22 @@ var EditUsers = (_ => {
processHeaderBarContainer (e) { processHeaderBarContainer (e) {
let channel = BDFDB.LibraryModules.ChannelStore.getChannel(e.instance.props.channelId); let channel = BDFDB.LibraryModules.ChannelStore.getChannel(e.instance.props.channelId);
if (channel && channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInDmHeader) { if (channel && channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInDmHeader) {
let [children, index] = BDFDB.ReactUtils.findParent(e.instance, {name: "Title"}); let userName = BDFDB.ReactUtils.findChild(e.instance, {name: "Title"});
if (index > -1) { if (userName) {
let recipientId = channel.getRecipientId(); let recipientId = channel.getRecipientId();
children[index].props.children = this.getUserData(recipientId).username; userName.props.children = this.getUserData(recipientId).username;
this.changeUserColor(children[index], recipientId); this.changeUserColor(userName, recipientId);
}
}
}
processChannelCallHeader (e) {
if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInDmHeader) {
let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Title"});
if (userName) {
let recipientId = e.instance.props.channel.getRecipientId();
userName.props.children = this.getUserData(recipientId).username;
this.changeUserColor(userName, recipientId);
} }
} }
} }
@ -350,8 +364,8 @@ var EditUsers = (_ => {
break; break;
} }
if (change) { if (change) {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props:[["className", BDFDB.disCN.username]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props:[["className", BDFDB.disCN.username]]});
if (index > -1) this.changeUserColor(children[index], e.instance.props.user.id, { if (userName) this.changeUserColor(userName, e.instance.props.user.id, {
changeBackground: changeBackground changeBackground: changeBackground
}); });
if (tagClass) this.injectBadge(e.returnvalue.props.children, e.instance.props.user.id, guildId, 2, { if (tagClass) this.injectBadge(e.returnvalue.props.children, e.instance.props.user.id, guildId, 2, {
@ -421,8 +435,8 @@ var EditUsers = (_ => {
if (titleIsName) e.instance.props.title = e.instance.props.priorityUser.user.username; if (titleIsName) e.instance.props.title = e.instance.props.priorityUser.user.username;
} }
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "Header"}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Header"});
if (index > -1) this.changeUserColor(children[index], e.instance.props.priorityUser.user.id); if (userName) this.changeUserColor(userName, e.instance.props.priorityUser.user.id);
} }
} }
} }
@ -435,8 +449,8 @@ var EditUsers = (_ => {
if (data && data.name) e.instance.props.nick = data.name; if (data && data.name) e.instance.props.nick = data.name;
} }
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.voicename]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.voicename]]});
if (index > -1) this.changeUserColor(children[index], e.instance.props.user.id, {modify: e.instance.props}); if (userName) this.changeUserColor(userName, e.instance.props.user.id, {modify: e.instance.props});
} }
} }
} }
@ -450,13 +464,13 @@ var EditUsers = (_ => {
} }
else { else {
if (data && (data.color1 || data.color2)) { if (data && (data.color1 || data.color2)) {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "Tooltip"}); let tooltip = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Tooltip"});
if (index > -1 && typeof children[index].props.children == "function") { if (tooltip && typeof tooltip.props.children == "function") {
let renderChildren = children[index].props.children; let renderChildren = tooltip.props.children;
children[index].props.children = (...args) => { tooltip.props.children = (...args) => {
let renderedChildren = renderChildren(...args); let renderedChildren = renderChildren(...args);
let [children2, index2] = BDFDB.ReactUtils.findParent(renderedChildren, {name: "PanelTitle"}); let userName = BDFDB.ReactUtils.findChild(renderedChildren, {name: "PanelTitle"});
if (index2 > -1) this.changeUserColor(children2[index2], e.instance.props.currentUser.id); if (userName) this.changeUserColor(userName, e.instance.props.currentUser.id);
return renderedChildren; return renderedChildren;
} }
} }
@ -469,18 +483,17 @@ var EditUsers = (_ => {
if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInChatWindow) { if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInChatWindow) {
let recipientId = e.instance.props.channel.getRecipientId(); let recipientId = e.instance.props.channel.getRecipientId();
let name = this.getUserData(recipientId).username; let name = this.getUserData(recipientId).username;
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue.props.children, {props:"src"}); let avatar = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {props: "src"});
if (index > -1) children[index].props.src = this.getUserAvatar(recipientId); if (avatar) avatar.props.src = this.getUserAvatar(recipientId);
[children, index] = BDFDB.ReactUtils.findParent(e.returnvalue.props.children, {name:"h1"}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {name: "h1"});
if (index > -1) { if (userName) {
children[index].props.children = BDFDB.ReactUtils.createElement("span", {children: name}); userName.props.children = BDFDB.ReactUtils.createElement("span", {children: name});
this.changeUserColor(children[index].props.children, recipientId); this.changeUserColor(userName.props.children, recipientId);
} }
if (index > -1) children[index].props.src = this.getUserAvatar(recipientId); userName = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {name: "strong"});
[children, index] = BDFDB.ReactUtils.findParent(e.returnvalue.props.children, {name:"strong"}); if (userName) {
if (index > -1) { userName.props.children = "@" + name;
children[index].props.children = "@" + name; this.changeUserColor(userName, recipientId);
this.changeUserColor(children[index], recipientId);
} }
} }
} }
@ -653,8 +666,8 @@ var EditUsers = (_ => {
if (e.instance.props.user && settings.changeInInviteList) { if (e.instance.props.user && settings.changeInInviteList) {
if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id); if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id);
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.invitemodalinviterowname]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.invitemodalinviterowname]]});
if (index > -1) this.changeUserColor(children[index], e.instance.props.user.id); if (userName) this.changeUserColor(userName, e.instance.props.user.id);
} }
} }
} }
@ -667,8 +680,8 @@ var EditUsers = (_ => {
processInviteModalUserRow (e) { processInviteModalUserRow (e) {
if (e.instance.props.user && settings.changeInInviteList) { if (e.instance.props.user && settings.changeInInviteList) {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.searchpopoutddmaddnickname]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.searchpopoutddmaddnickname]]});
if (index > -1) this.changeUserColor(children[index], e.instance.props.user.id); if (userName) this.changeUserColor(userName, e.instance.props.user.id);
} }
} }
@ -676,8 +689,8 @@ var EditUsers = (_ => {
if (BDFDB.ObjectUtils.is(e.instance.props.typingUsers) && Object.keys(e.instance.props.typingUsers).length && settings.changeInTyping) { if (BDFDB.ObjectUtils.is(e.instance.props.typingUsers) && Object.keys(e.instance.props.typingUsers).length && settings.changeInTyping) {
let users = Object.keys(e.instance.props.typingUsers).filter(id => id != BDFDB.UserUtils.me.id).filter(id => !BDFDB.LibraryModules.FriendUtils.isBlocked(id)).map(id => BDFDB.LibraryModules.UserStore.getUser(id)).filter(user => user); let users = Object.keys(e.instance.props.typingUsers).filter(id => id != BDFDB.UserUtils.me.id).filter(id => !BDFDB.LibraryModules.FriendUtils.isBlocked(id)).map(id => BDFDB.LibraryModules.UserStore.getUser(id)).filter(user => user);
if (users.length) { if (users.length) {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.typingtext]]}); let typingtext = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.typingtext]]});
if (index > -1 && BDFDB.ArrayUtils.is(children[index].props.children)) for (let child of children[index].props.children) if (child.type == "strong") { if (typingtext && BDFDB.ArrayUtils.is(typingtext.props.children)) for (let child of typingtext.props.children) if (child.type == "strong") {
let userId = (users.shift() || {}).id; let userId = (users.shift() || {}).id;
if (userId) { if (userId) {
let data = changedUsers[userId]; let data = changedUsers[userId];
@ -692,10 +705,10 @@ var EditUsers = (_ => {
processDirectMessage (e) { processDirectMessage (e) {
if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInRecentDms) { if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInRecentDms) {
let recipientId = e.instance.props.channel.getRecipientId(); let recipientId = e.instance.props.channel.getRecipientId();
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "ListItemTooltip"}); let tooltip = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "ListItemTooltip"});
if (index > -1) children[index].props.text = this.getUserData(recipientId).username; if (tooltip) tooltip.props.text = this.getUserData(recipientId).username;
[children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "NavItem"}); let avatar = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "NavItem"});
if (index > -1) children[index].props.icon = this.getUserAvatar(recipientId); if (avatar) avatar.props.icon = this.getUserAvatar(recipientId);
} }
} }
@ -723,11 +736,11 @@ var EditUsers = (_ => {
if (e.instance.props.user && settings.changeInQuickSwitcher) { if (e.instance.props.user && settings.changeInQuickSwitcher) {
if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id); if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id);
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props:[["className", BDFDB.disCN.quickswitchresultmatch]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props:[["className", BDFDB.disCN.quickswitchresultmatch]]});
if (index > -1) { if (userName) {
let data = changedUsers[e.instance.props.user.id]; let data = changedUsers[e.instance.props.user.id];
if (data && data.name) children[index].props.children = data.name; if (data && data.name) userName.props.children = data.name;
this.changeUserColor(children[index], e.instance.props.user.id, {modify: BDFDB.ObjectUtils.extract(e.instance.props, "focused", "unread", "mentions")}); this.changeUserColor(userName, e.instance.props.user.id, {modify: BDFDB.ObjectUtils.extract(e.instance.props, "focused", "unread", "mentions")});
} }
} }
} }
@ -741,11 +754,11 @@ var EditUsers = (_ => {
processSearchPopoutUserResult (e) { processSearchPopoutUserResult (e) {
if (e.instance.props.result && e.instance.props.result.user && settings.changeInSearchPopout) { if (e.instance.props.result && e.instance.props.result.user && settings.changeInSearchPopout) {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props:[["className", BDFDB.disCN.searchpopoutdisplayednick]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props:[["className", BDFDB.disCN.searchpopoutdisplayednick]]});
if (index > -1) { if (userName) {
let data = changedUsers[e.instance.props.result.user.id]; let data = changedUsers[e.instance.props.result.user.id];
if (data && data.name) children[index].props.children = data.name; if (data && data.name) userName.props.children = data.name;
this.changeUserColor(children[index], e.instance.props.result.user.id); this.changeUserColor(userName, e.instance.props.result.user.id);
} }
} }
} }
@ -763,18 +776,26 @@ var EditUsers = (_ => {
e.instance.props.avatarUrl = this.getUserAvatar(user.id); e.instance.props.avatarUrl = this.getUserAvatar(user.id);
} }
else { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props:[["className", BDFDB.disCN.callmembers]]}); let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props:[["className", BDFDB.disCN.callmembers]]});
if (index > -1) this.changeUserColor(children[index], user.id); if (userName) this.changeUserColor(userName, user.id);
} }
} }
} }
} }
processRTCConnection (e) { processRTCConnection (e) {
if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInRecentDms) { if (e.instance.props.channel && e.instance.props.channel.type == BDFDB.DiscordConstants.ChannelTypes.DM && settings.changeInRecentDms && typeof e.returnvalue.props.children == "function") {
let recipientId = e.instance.props.channel.getRecipientId(); let recipientId = e.instance.props.channel.getRecipientId();
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "PanelSubtext"}); let renderChildren = e.returnvalue.props.children;
if (index > -1) children[index].props.children = "@" + this.getUserData(recipientId).username; e.returnvalue.props.children = (...args) => {
let renderedChildren = renderChildren(...args);
let userName = BDFDB.ReactUtils.findChild(renderedChildren, {name: "PanelSubtext"});
if (userName) {
userName.props.children = "@" + this.getUserData(recipientId).username;
this.changeUserColor(userName, recipientId);
}
return renderedChildren;
};
} }
} }
@ -790,6 +811,17 @@ var EditUsers = (_ => {
} }
} }
processPictureInPictureVideo (e) {
if (e.instance.props.backgroundKey) {
let user = BDFDB.LibraryModules.UserStore.getUser(e.instance.props.backgroundKey);
if (user) {
e.instance.props.title = this.getUserData(user.id).username;
let videoBackground = BDFDB.ReactUtils.findChild(e.instance.props.children, {name: "VideoBackground"});
if (videoBackground && videoBackground.props.src) videoBackground.props.src = this.getUserAvatar(user.id);
}
}
}
processUserSummaryItem (e) { processUserSummaryItem (e) {
if (BDFDB.ArrayUtils.is(e.instance.props.users)) { if (BDFDB.ArrayUtils.is(e.instance.props.users)) {
for (let i in e.instance.props.users) if (e.instance.props.users[i]) e.instance.props.users[i] = this.getUserData(e.instance.props.users[i].id); for (let i in e.instance.props.users) if (e.instance.props.users[i]) e.instance.props.users[i] = this.getUserData(e.instance.props.users[i].id);
@ -799,12 +831,9 @@ var EditUsers = (_ => {
changeAppTitle () { changeAppTitle () {
let channel = BDFDB.LibraryModules.ChannelStore.getChannel(BDFDB.LibraryModules.LastChannelStore.getChannelId()); let channel = BDFDB.LibraryModules.ChannelStore.getChannel(BDFDB.LibraryModules.LastChannelStore.getChannelId());
let title = document.head.querySelector("title"); let title = document.head.querySelector("title");
if (title && channel && channel.type == 1) { if (title && channel && channel.type == BDFDB.DiscordConstants.ChannelTypes.DM) {
let info = BDFDB.LibraryModules.UserStore.getUser(channel.recipients[0]); let user = BDFDB.LibraryModules.UserStore.getUser(channel.recipients[0]);
if (info) { if (user) BDFDB.DOMUtils.setText(title, "@" + this.getUserData(user.id, settings.changeInAppTitle).username);
let data = this.getUserData(info.id, title);
BDFDB.DOMUtils.setText(title, "@" + (data.name || info.username));
}
} }
} }