/** * @name EditUsers * @author DevilBro * @authorId 278543574059057154 * @version 4.6.9 * @description Allows you to locally edit Users * @invite Jx3TjNS * @donate https://www.paypal.me/MircoWittrien * @patreon https://www.patreon.com/MircoWittrien * @website https://mwittrien.github.io/ * @source https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/EditUsers/ * @updateUrl https://mwittrien.github.io/BetterDiscordAddons/Plugins/EditUsers/EditUsers.plugin.js */ module.exports = (_ => { const changeLog = { }; return !window.BDFDB_Global || (!window.BDFDB_Global.loaded && !window.BDFDB_Global.started) ? class { constructor (meta) {for (let key in meta) this[key] = meta[key];} getName () {return this.name;} getAuthor () {return this.author;} getVersion () {return this.version;} getDescription () {return `The Library Plugin needed for ${this.name} is missing. Open the Plugin Settings to download it. \n\n${this.description}`;} downloadLibrary () { require("request").get("https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js", (e, r, b) => { if (!e && b && r.statusCode == 200) require("fs").writeFile(require("path").join(BdApi.Plugins.folder, "0BDFDB.plugin.js"), b, _ => BdApi.showToast("Finished downloading BDFDB Library", {type: "success"})); else BdApi.alert("Error", "Could not download BDFDB Library Plugin. Try again later or download it manually from GitHub: https://mwittrien.github.io/downloader/?library"); }); } load () { if (!window.BDFDB_Global || !Array.isArray(window.BDFDB_Global.pluginQueue)) window.BDFDB_Global = Object.assign({}, window.BDFDB_Global, {pluginQueue: []}); if (!window.BDFDB_Global.downloadModal) { window.BDFDB_Global.downloadModal = true; BdApi.showConfirmationModal("Library Missing", `The Library Plugin needed for ${this.name} is missing. Please click "Download Now" to install it.`, { confirmText: "Download Now", cancelText: "Cancel", onCancel: _ => {delete window.BDFDB_Global.downloadModal;}, onConfirm: _ => { delete window.BDFDB_Global.downloadModal; this.downloadLibrary(); } }); } if (!window.BDFDB_Global.pluginQueue.includes(this.name)) window.BDFDB_Global.pluginQueue.push(this.name); } start () {this.load();} stop () {} getSettingsPanel () { let template = document.createElement("template"); template.innerHTML = `
The Library Plugin needed for ${this.name} is missing.\nPlease click Download Now to install it.
`; template.content.firstElementChild.querySelector("a").addEventListener("click", this.downloadLibrary); return template.content.firstElementChild; } } : (([Plugin, BDFDB]) => { var changedUsers = {}; return class EditUsers extends Plugin { onLoad () { this.defaults = { types: { servers: {value: true, description: "Servers"}, dms: {value: true, description: "Direct Messages"}, }, places: { contextMenu: {value: true, description: "User ContextMenu"}, chatTextarea: {value: true, description: "Chat Textarea"}, chatWindow: {value: true, description: "Messages"}, reactions: {value: true, description: "Reactions"}, mentions: {value: true, description: "Mentions"}, memberList: {value: true, description: "Member List"}, voiceChat: {value: true, description: "Voice Channels"}, recentDms: {value: true, description: "Direct Message Notifications"}, dmsList: {value: true, description: "Direct Message List"}, dmHeader: {value: true, description: "Direct Message Header"}, dmCalls: {value: true, description: "Calls/ScreenShares"}, typing: {value: true, description: "Typing List"}, friendList: {value: true, description: "Friend List"}, inviteList: {value: true, description: "Invite List"}, activity: {value: true, description: "Activity Page"}, userPopout: {value: true, description: "User Popouts"}, userProfile: {value: true, description: "User Profile Modal"}, mutualFriends: {value: true, description: "Mutual Friends"}, autocompletes: {value: true, description: "Autocomplete Menu"}, guildSettings: {value: true, description: "Server Settings"}, quickSwitcher: {value: true, description: "Quick Switcher"}, searchPopout: {value: true, description: "Search Popout"}, userAccount: {value: true, description: "Your Account Information"}, appTitle: {value: true, description: "Discord App Title (DMs)"} } }; this.patchedModules = { before: { HeaderBarContainer: "default", ChannelEditorContainer: "render", AutocompleteUserResult: "render", UserThemedBanner: "default", UserBanner: "default", UserBannerMask: "default", UserPopoutAvatar: "UserPopoutAvatar", UserThemePopoutHeader: "default", UsernameSection: "default", UserPopoutInfo: "UserPopoutInfo", UserProfileModal: "default", UserProfileModalHeader: "default", UserInfo: "default", NowPlayingItem: "default", VoiceUser: "render", RTCConnectionVoiceUsers: "default", Account: "render", Message: "default", MessageUsername: "default", MessageContent: "type", ThreadMessageAccessoryMessage: "default", ReactorsComponent: "render", ChannelReply: "default", MemberListItem: "render", AuditLogs: "render", GuildSettingsAuditLogEntry: "render", GuildSettingsEmoji: "render", MemberCard: "render", SettingsInvites: "render", GuildSettingsBans: "render", InvitationCard: "render", PrivateChannel: "render", PrivateChannelRecipientsInvitePopout: "render", QuickSwitchUserResult: "render", SearchPopoutComponent: "render", PrivateChannelCallParticipants: "render", ChannelCall: "render", ChannelCallGrid: "default", HorizontalVideoParticipants: "default", PictureInPictureVideo: "default", UserSummaryItem: "render" }, after: { ChannelCallHeader: "default", AutocompleteUserResult: "render", DiscordTag: "default", NameTag: "default", FocusRing: "FocusRing", UserPopoutExperimentWrapper: "default", UserPopoutContainer: "type", UsernameSection: "default", UserPopoutInfo: "UserPopoutInfo", MutualFriends: "default", VoiceUser: "render", ParticipantsForSelectedParticipant: "default", PrivateChannelEmptyMessage: "default", PanelTitle: "default", MessageUsername: "default", MessageContent: "type", ReactorsComponent: "render", UserMention: "default", RichUserMention: "UserMention", ChannelReply: "default", MemberListItem: "render", InvitationCard: "render", InviteModalUserRow: "default", TypingUsers: "render", DirectMessage: "render", RTCConnection: "render", PrivateChannel: "render", QuickSwitcherConnected: "default", QuickSwitchUserResult: "render", IncomingCallModal: "default" } }; this.patchPriority = 3; this.css = ` ${BDFDB.dotCN.messageavatar} { background-size: cover; object-fit: cover; } ${BDFDB.dotCNS.chat + BDFDB.dotCN.messageusername}:hover > span[style*="color"], ${BDFDB.dotCN.voicedetailschannel}:hover > span[style*="color"], ${BDFDB.dotCN.messageswelcomethreadcreator}:hover > span[style*="color"] { text-decoration: underline; } ${BDFDB.dotCNS.dmchannel + BDFDB.dotCN.bottag} { margin-left: 4px; } ${BDFDB.dotCNS.peoplesuser + BDFDB.dotCN.peoplesdiscriminator} { display: none; } ${BDFDB.dotCNS.peoplesuserhovered + BDFDB.dotCN.peoplesdiscriminator} { display: block; } ${BDFDB.dotCN.messagemarkup} span[style*="linear-gradient"] code.inline, ${BDFDB.dotCN.messagemarkup} span[style*="linear-gradient"] blockquote, ${BDFDB.dotCN.messagemarkup} span[style*="linear-gradient"] ${BDFDB.dotCN.spoilertext} { color: var(--text-normal); } `; } onStart () { let observer = new MutationObserver(_ => {this.changeAppTitle();}); BDFDB.ObserverUtils.connect(this, document.head.querySelector("title"), {name: "appTitleObserver", instance: observer}, {childList: true}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryStores.RelationshipStore, "getName", {after: e => { if (e.methodArguments[2] && changedUsers[e.methodArguments[2].id] && changedUsers[e.methodArguments[2].id].name) return changedUsers[e.methodArguments[2].id].name; }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryStores.StageChannelParticipantStore, "getMutableParticipants", {after: e => { if (BDFDB.ArrayUtils.is(e.returnValue)) for (let i in e.returnValue) { if (e.returnValue[i] && e.returnValue[i].user && changedUsers[e.returnValue[i].user.id]) e.returnValue[i] = Object.assign({}, e.returnValue[i], {user: this.getUserData(e.returnValue[i].user.id)}); } }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.MessageAuthorUtils, ["default", "getMessageAuthor"], {after: e => { if (this.settings.places.chatWindow && e.methodArguments[0] && e.methodArguments[0].author && changedUsers[e.methodArguments[0].author.id] && this.shouldChangeInChat(e.methodArguments[0].channel_id)) { let data = changedUsers[e.methodArguments[0].author.id]; if (data) { let member = BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.methodArguments[0].channel_id) || {}).guild_id, e.methodArguments[0].author.id); let color1 = data.color1 && data.useRoleColor && member && member.colorString || data.color1; color1 = color1 && BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); e.returnValue = Object.assign({}, e.returnValue, { nick: this.getUserNick(e.methodArguments[0].author.id, member && member.nick) || e.returnValue.nick, guildMemberAvatar: (data.removeIcon || data.url) ? null : e.returnValue.guildMemberAvatar, colorString: color1 || e.returnValue.colorString }); } } }}); let searchGroupData = BDFDB.ObjectUtils.get(BDFDB.ModuleUtils.findByName("SearchPopoutComponent", false), "exports.GroupData"); if (BDFDB.ObjectUtils.is(searchGroupData)) { BDFDB.PatchUtils.patch(this, searchGroupData.FILTER_FROM, "component", {after: e => { if (typeof e.returnValue.props.renderResult == "function") { let renderResult = e.returnValue.props.renderResult; e.returnValue.props.renderResult = (...args) => { let result = renderResult(...args); this.processSearchPopoutUserResult({instance: {props: e.methodArguments[0]}, returnvalue: result}); return result; }; } }}); BDFDB.PatchUtils.patch(this, searchGroupData.FILTER_MENTIONS, "component", {after: e => { if (typeof e.returnValue.props.renderResult == "function") { let renderResult = e.returnValue.props.renderResult; e.returnValue.props.renderResult = (...args) => { let result = renderResult(...args); this.processSearchPopoutUserResult({instance: {props: e.methodArguments[0]}, returnvalue: result}); return result; }; } }}); } BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.QuerySearchUtils, ["queryDMUsers", "queryFriends"], {after: e => { if (!e.methodArguments[0].query) return; for (let id in changedUsers) if (changedUsers[id] && changedUsers[id].name && changedUsers[id].name.toLocaleLowerCase().indexOf(e.methodArguments[0].query.toLocaleLowerCase()) > -1 && !e.returnValue.find(n => n.record && n.record.id == id && n.type == BDFDB.DiscordConstants.AutocompleterResultTypes.USER)) { let user = BDFDB.LibraryStores.UserStore.getUser(id); if (user) e.returnValue.push({ comparator: user.username, record: user, score: 10, sortable: user.username.toLocaleLowerCase(), type: BDFDB.DiscordConstants.AutocompleterResultTypes.USER }); } }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.QuerySearchUtils, "queryGuildUsers", {after: e => { if (!e.methodArguments[0].query) return; for (let id in changedUsers) if (changedUsers[id] && changedUsers[id].name && changedUsers[id].name.toLocaleLowerCase().indexOf(e.methodArguments[0].query.toLocaleLowerCase()) > -1 && !e.returnValue.find(n => n.record && n.record.id == id && n.type == BDFDB.DiscordConstants.AutocompleterResultTypes.USER)) { let user = BDFDB.LibraryStores.UserStore.getUser(id); let member = user && e.methodArguments[0].guildId && BDFDB.LibraryStores.GuildMemberStore.getMember(e.methodArguments[0].guildId, id); if (user) e.returnValue.push({ comparator: member && member.nick ? member.nick.toLocaleLowerCase() : user.username.toLocaleLowerCase(), record: user, score: 0, type: BDFDB.DiscordConstants.AutocompleterResultTypes.USER }); } }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.QuerySearchUtils, "queryChannelUsers", {after: e => { if (!e.methodArguments[0].query) return; for (let id in changedUsers) if (changedUsers[id] && changedUsers[id].name && changedUsers[id].name.toLocaleLowerCase().indexOf(e.methodArguments[0].query.toLocaleLowerCase()) > -1 && !e.returnValue.find(n => n.record && n.record.id == id && n.type == BDFDB.DiscordConstants.AutocompleterResultTypes.USER)) { let user = BDFDB.LibraryStores.UserStore.getUser(id); let member = user && e.methodArguments[0].channelId && BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.methodArguments[0].channelId) || {}).guild_id, id); if (user) e.returnValue.push({ comparator: member && member.nick ? member.nick.toLocaleLowerCase() : user.username.toLocaleLowerCase(), record: user, score: 0, type: BDFDB.DiscordConstants.AutocompleterResultTypes.USER }); } }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.IconUtils, "getUserBannerURL", {instead: e => { let data = changedUsers[e.methodArguments[0].id]; if (data) { if (data.removeBanner) return null; else if (data.banner) return data.banner; } return e.callOriginalMethod(); }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.MemberDisplayUtils, "getDisplayProfile", {after: e => { if (!e.returnValue) return; let data = changedUsers[e.methodArguments[0]]; if (data && (data.banner || data.removeBanner)) { e.returnValue = new BDFDB.DiscordObjects.DisplayProfile(e.returnValue, e.returnValue); if (data.removeBanner) e.returnValue.banner = null; else if (data.banner) e.returnValue.banner = data.banner; } }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryStores.PresenceStore, "findActivity", {after: e => { let data = changedUsers[e.methodArguments[0]]; if (data && (data.removeStatus || data.status || data.statusEmoji) && (e.returnValue && e.returnValue.type === BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS || !e.returnValue && e.methodArguments[1] && e.methodArguments[1].toString().indexOf("type===") > -1 && e.methodArguments[1].toString().indexOf("CUSTOM_STATUS") > -1)) return this.createCustomStatus(changedUsers[e.methodArguments[0]]); }}); this.forceUpdateAll(); } onStop () { this.forceUpdateAll(); } getSettingsPanel (collapseStates = {}) { let settingsPanel; return settingsPanel = BDFDB.PluginUtils.createSettingsPanel(this, { collapseStates: collapseStates, children: _ => { let settingsItems = []; settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelList, { title: "Change Users in:", children: Object.keys(this.defaults.places).map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, { type: "Switch", plugin: this, keys: ["places", key], label: this.defaults.places[key].description, value: this.settings.places[key] })) })); settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelList, { title: "Change Users in the Chat Window (Messages, Reactions, Mentions, etc.) in:", children: Object.keys(this.defaults.types).map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, { type: "Switch", plugin: this, keys: ["types", key], label: this.defaults.types[key].description, value: this.settings.types[key] })) })); settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsLabel, { label: "Changed Users:" })); settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Button", color: BDFDB.LibraryComponents.Button.Colors.RED, label: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { children: !Object.keys(changedUsers).length ? BDFDB.LanguageUtils.LanguageStrings.NONE : Object.keys(changedUsers).filter(BDFDB.LibraryStores.UserStore.getUser).map(id => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, { text: this.getUserData(id).username, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Avatars.Avatar, { className: BDFDB.disCN.listavatar, src: this.getUserAvatar(id), size: BDFDB.LibraryComponents.Avatars.Sizes.SIZE_32, onClick: _ => this.openUserSettingsModal(BDFDB.LibraryStores.UserStore.getUser(id)) }) })) }), onClick: _ => { BDFDB.ModalUtils.confirm(this, this.labels.confirm_resetall, _ => { BDFDB.DataUtils.remove(this, "users"); BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates); this.forceUpdateAll(); }); }, children: BDFDB.LanguageUtils.LanguageStrings.RESET })); return settingsItems; } }); } onSettingsClosed () { if (this.SettingsUpdated) { delete this.SettingsUpdated; this.forceUpdateAll(); } } forceUpdateAll () { changedUsers = BDFDB.DataUtils.load(this, "users"); this.changeAppTitle(); BDFDB.PatchUtils.forceAllUpdates(this); BDFDB.DiscordUtils.rerenderAll(); } onDMContextMenu (e) { if (e.instance.props.user) { if (this.settings.places.contextMenu) { let userName = this.getUserData(e.instance.props.user.id).username; if (userName != e.instance.props.user.username) { let [muteChildren, muteIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "mute-channel"}); if (muteIndex > -1) muteChildren[muteIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("MUTE_CHANNEL", `@${userName}`); let [unmuteChildren, unmuteIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "unmute-channel"}); if (unmuteIndex > -1) unmuteChildren[unmuteIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("UNMUTE_CHANNEL", `@${userName}`); } } let [children, index] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "devmode-copy-id", group: true}); children.splice(index > -1 ? index : children.length, 0, BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuGroup, { children: this.createContextMenuEntry(e.instance.props.user) })); } } onUserContextMenu (e) { if (e.instance.props.channel && e.instance.props.channel.isDM()) { const user = BDFDB.LibraryStores.UserStore.getUser(e.instance.props.channel.getRecipientId()); if (user && this.settings.places.contextMenu && e.subType == "useMuteChannelItem") { let userName = this.getUserData(user.id).username; if (userName != user.username) { let [muteChildren, muteIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "mute-channel"}); if (muteIndex > -1) muteChildren[muteIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("MUTE_CHANNEL", `@${userName}`); let [unmuteChildren, unmuteIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "unmute-channel"}); if (unmuteIndex > -1) unmuteChildren[unmuteIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("UNMUTE_CHANNEL", `@${userName}`); } } } if (e.instance.props.user) { if (this.settings.places.contextMenu && e.subType == "useUserManagementItems") { let userName = this.getUserData(e.instance.props.user.id).username; if (userName != e.instance.props.user.username) { let [timeoutChildren, timeoutIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "timeout"}); if (timeoutIndex > -1) timeoutChildren[timeoutIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("DISABLE_GUILD_COMMUNICATION_FOR_USER", userName); let [removeTimeoutChildren, removeTimeoutIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "removetimeout"}); if (removeTimeoutIndex > -1) removeTimeoutChildren[removeTimeoutIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("ENABLE_GUILD_COMMUNICATION_FOR_USER", userName); let [kickChildren, kickIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "kick"}); if (kickIndex > -1) kickChildren[kickIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("KICK_USER", userName); let [banChildren, banIndex] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "ban"}); if (banIndex > -1) banChildren[banIndex].props.label = BDFDB.LanguageUtils.LanguageStringsFormat("BAN_USER", userName); } } if (e.subType == "useBlockUserItem") { if (e.returnvalue.length) e.returnvalue.push(BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuSeparator, {})); e.returnvalue.push(this.createContextMenuEntry(e.instance.props.user)); } } } createContextMenuEntry (user) { return BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { label: this.labels.context_localusersettings, id: BDFDB.ContextMenuUtils.createItemId(this.name, "settings-submenu"), children: BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuGroup, { children: [ BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { label: this.labels.submenu_usersettings, id: BDFDB.ContextMenuUtils.createItemId(this.name, "settings-change"), action: _ => this.openUserSettingsModal(user) }), BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { label: this.labels.submenu_resetsettings, id: BDFDB.ContextMenuUtils.createItemId(this.name, "settings-reset"), color: BDFDB.DiscordConstants.MenuItemColors.DANGER, disabled: !changedUsers[user.id], action: event => { let remove = _ => { BDFDB.DataUtils.remove(this, "users", user.id); this.forceUpdateAll(true); }; if (event.shiftKey) remove(); else BDFDB.ModalUtils.confirm(this, this.labels.confirm_reset, remove); } }) ] }) }); } processChannelEditorContainer (e) { if (!e.instance.props.disabled && e.instance.props.channel && e.instance.props.channel.isDM() && (e.instance.props.type == BDFDB.DiscordConstants.ChannelTextAreaTypes.NORMAL || e.instance.props.type == BDFDB.DiscordConstants.ChannelTextAreaTypes.NORMAL_WITH_ACTIVITY) && this.settings.places.chatTextarea) { let user = BDFDB.LibraryStores.UserStore.getUser(e.instance.props.channel.recipients[0]); if (user) e.instance.props.placeholder = BDFDB.LanguageUtils.LanguageStringsFormat("TEXTAREA_PLACEHOLDER", `@${changedUsers[user.id] && changedUsers[user.id].name || user.username}`); } } processAutocompleteUserResult (e) { if (e.instance.props.user && this.settings.places.autocompletes) { if (!e.returnvalue) { e.instance.props.user = this.getUserData(e.instance.props.user.id); let data = changedUsers[e.instance.props.user.id]; if (data && data.name) e.instance.props.nick = data.name; } else { if (typeof e.returnvalue.props.children == "function") { let childrenRender = e.returnvalue.props.children; e.returnvalue.props.children = BDFDB.TimeUtils.suppress((...args) => { let children = childrenRender(...args); let userName = BDFDB.ReactUtils.findChild(children, {name: "AutocompleteRowHeading"}); if (userName) this.changeUserColor(userName, e.instance.props.user.id); return children; }, "Error in Children Render of AutocompleteUserResult!", this); } } } } processHeaderBarContainer (e) { let channel = BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.channelId); if (channel && channel.isDM() && this.settings.places.dmHeader) { let userName = BDFDB.ReactUtils.findChild(e.instance, {props: [["className", BDFDB.disCN.channelheadercursorpointer]]}); if (userName) { let recipientId = channel.getRecipientId(); userName.props.children = this.getUserData(recipientId).username; this.changeUserColor(userName, recipientId); } } } processChannelCallHeader (e) { if (e.instance.props.channel && this.settings.places.dmHeader && e.instance.props.channel.isDM()) { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Title"}); if (userName) { let recipientId = e.instance.props.channel.getRecipientId(); if (changedUsers[recipientId]) { userName.props.children = this.getUserData(recipientId).username; this.changeUserColor(userName, recipientId); } } } } processDiscordTag (e) { this.processNameTag(e); } processNameTag (e) { if (e.returnvalue && e.instance.props.user && (e.instance.props.className || e.instance.props.usernameClass)) { let change = false, guildId = null; let tagClass = ""; if (e.instance.props.className) { if (e.instance.props.className.indexOf(BDFDB.disCN.userpopoutheadertagnonickname) > -1) { change = this.settings.places.userPopout; guildId = BDFDB.LibraryStores.SelectedGuildStore.getGuildId(); tagClass = BDFDB.disCNS.userpopoutheaderbottag + BDFDB.disCN.bottagnametag; } else if (e.instance.props.className.indexOf(BDFDB.disCN.userpopoutusernametagnonickname) > -1) { change = this.settings.places.userPopout; guildId = BDFDB.LibraryStores.SelectedGuildStore.getGuildId(); tagClass = BDFDB.disCNS.userpopoutusernamebottag + BDFDB.disCN.bottagnametag; } else if (e.instance.props.className.indexOf(BDFDB.disCN.guildsettingsinviteusername) > -1) { change = this.settings.places.guildSettings; } else if (e.instance.props.className.indexOf(BDFDB.disCN.peoplesdiscordtag) > -1) { change = this.settings.places.friendList; tagClass = BDFDB.disCN.bottagnametag; } } if (e.instance.props.usernameClass) { if (e.instance.props.usernameClass.indexOf(BDFDB.disCN.messagereactionsmodalusername) > -1) { change = this.settings.places.reactions && !BDFDB.LibraryStores.GuildMemberStore.getNick(BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), e.instance.props.user.id); } else if (e.instance.props.usernameClass.indexOf(BDFDB.disCN.userprofileusername) > -1) { change = this.settings.places.userProfile; guildId = BDFDB.LibraryStores.SelectedGuildStore.getGuildId(); tagClass = BDFDB.disCNS.userprofilebottag + BDFDB.disCN.bottagnametag; } } if (change) { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.username]]}); if (userName) this.changeUserColor(userName, e.instance.props.user.id); if (tagClass) this.injectBadge(e.returnvalue.props.children, e.instance.props.user.id, guildId, 2, { tagClass: tagClass, useRem: e.instance.props.useRemSizes, inverted: e.instance.props.invertBotTagColor }); } } } processFocusRing (e) { if (e.returnvalue && e.returnvalue.props.className) { let change, userId, nameClass, modify = {}; if (this.settings.places.chatWindow && e.returnvalue.props.className.indexOf(BDFDB.disCN.messageswelcomethreadcreator) > -1) { change = true; userId = BDFDB.ReactUtils.findValue(e.returnvalue._owner, "userId", {up: true}); } if (change && userId) { if (changedUsers[userId]) { let name = nameClass ? BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", nameClass]]}) : e.returnvalue; if (name) { if (changedUsers[userId].name) name.props.children = changedUsers[userId].name; this.changeUserColor(name, userId, modify); } } } } } processUserThemedBanner (e) { this.processUserBanner(e); } processUserBanner (e) { if (e.instance.props.user && changedUsers[e.instance.props.user.id]) { if (changedUsers[e.instance.props.user.id].removeBanner) { e.instance.props.bannerSrc = null; e.instance.props.displayProfile.banner = null; } else if (changedUsers[e.instance.props.user.id].banner) { e.instance.props.bannerSrc = changedUsers[e.instance.props.user.id].banner; e.instance.props.displayProfile.banner = changedUsers[e.instance.props.user.id].banner; } } } processUserBannerMask (e) { if (e.instance.props.user && changedUsers[e.instance.props.user.id]) { if (changedUsers[e.instance.props.user.id].removeBanner) e.instance.props.isPremium = false; else if (changedUsers[e.instance.props.user.id].banner) e.instance.props.isPremium = true; } } processUserPopoutAvatar (e) { this.processUserThemePopoutHeader(e); } processUserThemePopoutHeader (e) { if (this.settings.places.userPopout && e.instance.props.user && changedUsers[e.instance.props.user.id]) e.instance.props.user = this.getUserData(e.instance.props.user.id, true, true); if (e.instance.props.displayProfile && e.instance.props.user && changedUsers[e.instance.props.user.id]) { if (changedUsers[e.instance.props.user.id].removeBanner) e.instance.props.displayProfile.banner = null; else if (changedUsers[e.instance.props.user.id].banner) e.instance.props.displayProfile.banner = changedUsers[e.instance.props.user.id].banner; } } processUserPopoutExperimentWrapper (e) { if (e.returnvalue.props.user && this.settings.places.userPopout && changedUsers[e.returnvalue.props.user.id]) e.returnvalue.props.user = this.getUserData(e.returnvalue.props.user.id, true, true); } processUserPopoutContainer (e) { if (e.returnvalue.props.user && this.settings.places.userPopout && changedUsers[e.returnvalue.props.user.id]) e.returnvalue.props.user = this.getUserData(e.returnvalue.props.user.id, true, true); } processUsernameSection (e) { if (e.instance.props.user && this.settings.places.userPopout) { let data = changedUsers[e.instance.props.user.id]; if (!data) return; if (!e.returnvalue) { let nickname = this.getUserNick(e.instance.props.user.id, e.instance.props.nickname); e.instance.props.nickname = nickname ? nickname : null; } else { if (data.color1 || data.tag) { let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.userpopoutusernamenickname]]}); if (index > -1) { this.changeUserColor(children[index], e.instance.props.user.id); if (!BDFDB.ArrayUtils.is(children[index].props.children)) children[index].props.children = [children[index].props.children].flat(10); this.injectBadge(children[index].props.children, e.instance.props.user.id, BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), 2, { tagClass: BDFDB.disCNS.userpopoutheaderbottag + BDFDB.disCN.bottagnametag, inverted: typeof e.instance.getMode == "function" && e.instance.getMode() !== "Normal" }); } } } } } processUserPopoutInfo (e) { if (e.instance.props.user && this.settings.places.userPopout) { let data = changedUsers[e.instance.props.user.id]; if (!data) return; if (!e.returnvalue) { let nickname = this.getUserNick(e.instance.props.user.id, e.instance.props.nickname); e.instance.props.nickname = nickname ? nickname : null; } else { if (data.color1 || data.tag) { let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {props: [["className", BDFDB.disCN.userpopoutheadernickname]]}); if (index > -1) { this.changeUserColor(children[index], e.instance.props.user.id); if (!BDFDB.ArrayUtils.is(children[index].props.children)) children[index].props.children = [children[index].props.children].flat(10); this.injectBadge(children[index].props.children, e.instance.props.user.id, BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), 2, { tagClass: BDFDB.disCNS.userpopoutheaderbottag + BDFDB.disCN.bottagnametag, inverted: typeof e.instance.getMode == "function" && e.instance.getMode() !== "Normal" }); } } } } } processUserProfileModal (e) { if (e.instance.props.user && this.settings.places.userProfile) e.instance.props.user = this.getUserData(e.instance.props.user.id); } processUserProfileModalHeader (e) { if (e.instance.props.user && this.settings.places.userProfile) e.instance.props.user = this.getUserData(e.instance.props.user.id); } processMutualFriends (e) { if (this.settings.places.mutualFriends) { let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "FriendRow"}); if (index > -1) for (let row of children) if (row && row.props && row.props.user) row.props.user = this.getUserData(row.props.user.id); } } processUserInfo (e) { if (e.instance.props.user && this.settings.places.friendList) { e.instance.props.user = this.getUserData(e.instance.props.user.id); if (BDFDB.ReactUtils.isValidElement(e.instance.props.subText)) { let data = changedUsers[e.instance.props.user.id]; if (data && (data.removeStatus || data.status || data.statusEmoji)) { e.instance.props.subText.props.activities = [].concat(e.instance.props.subText.props.activities).filter(n => n && n.type != BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS); let activity = this.createCustomStatus(data); if (activity) e.instance.props.subText.props.activities.unshift(activity); } } } } processNowPlayingItem (e) { if (this.settings.places.activity) { let [children, index] = BDFDB.ReactUtils.findParent(e.instance, {name: "NowPlayingHeader"}); if (index > -1) for (let child of children) if (child && child.props && child.props.party) { if (child.type && child.type.displayName == "NowPlayingHeader") { const type = child.type; child.type = (...args) => { const returnValue = type(...args); if (BDFDB.ObjectUtils.get(returnValue, "props.priorityUser.user.username") == returnValue.props.title) { returnValue.props.title = BDFDB.ReactUtils.createElement("span", {children: returnValue.props.title}); this.changeUserColor(returnValue.props.title, returnValue.props.priorityUser.user.id); } return returnValue; }; } child.props.party = Object.assign({}, child.props.party); if (child.props.party.partiedMembers) for (let i in child.props.party.partiedMembers) if (child.props.party.partiedMembers[i]) child.props.party.partiedMembers[i] = this.getUserData(child.props.party.partiedMembers[i].id); if (child.props.party.priorityMembers) for (let i in child.props.party.priorityMembers) if (child.props.party.priorityMembers[i]) child.props.party.priorityMembers[i] = Object.assign({}, child.props.party.priorityMembers[i], {user: this.getUserData(child.props.party.priorityMembers[i].user.id)}); if (child.props.party.voiceChannels) for (let i in child.props.party.voiceChannels) if (child.props.party.voiceChannels[i]) child.props.party.voiceChannels[i] = Object.assign({}, child.props.party.voiceChannels[i], {members: [].concat(child.props.party.voiceChannels[i].members).map(user => this.getUserData(user.id))}); } } } processVoiceUser (e) { if (e.instance.props.user && this.settings.places.voiceChat) { if (!e.returnvalue) { e.instance.props.user = this.getUserData(e.instance.props.user.id); let data = changedUsers[e.instance.props.user.id]; if (data && data.name) { let member = BDFDB.LibraryStores.GuildMemberStore.getMember(BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), e.instance.props.user.id); e.instance.props.nick = this.getUserNick(e.instance.props.user.id, e.instance.props.nick) || e.instance.props.nick; } } else { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.voicename]]}); if (userName) this.changeUserColor(userName, e.instance.props.user.id, {modify: e.instance.props}); } } } processRTCConnectionVoiceUsers (e) { if (e.instance.props.voiceStates && this.settings.places.voiceChat) for (let i in e.instance.props.voiceStates) { let data = changedUsers[e.instance.props.voiceStates[i].user.id]; if (data) { e.instance.props.voiceStates[i] = Object.assign({}, e.instance.props.voiceStates[i]); e.instance.props.voiceStates[i].user = this.getUserData(e.instance.props.voiceStates[i].user.id); e.instance.props.voiceStates[i].nick = this.getUserNick(e.instance.props.voiceStates[i].user.id, e.instance.props.voiceStates[i].member.nick) || e.instance.props.voiceStates[i].nick; } } } processAccount (e) { if (e.instance.props.currentUser && this.settings.places.userAccount) { let data = changedUsers[e.instance.props.currentUser.id]; if (!e.returnvalue) { e.instance.props.currentUser = this.getUserData(e.instance.props.currentUser.id); if (data && (data.removeStatus || data.status || data.statusEmoji)) e.instance.props.customStatusActivity = this.createCustomStatus(data); } } } processPanelTitle (e) { if (this.settings.places.userAccount) { let data = changedUsers[BDFDB.UserUtils.me.id]; let user = data && this.getUserData(BDFDB.UserUtils.me.id); if (user && e.instance.props.children == user.username) { if (data.color1) this.changeUserColor(e.returnvalue, BDFDB.UserUtils.me.id); } } } processPrivateChannelEmptyMessage (e) { if (e.instance.props.channel && e.instance.props.channel.isDM() && this.settings.places.chatWindow) { let recipientId = e.instance.props.channel.getRecipientId(); let name = this.getUserData(recipientId).username; let avatar = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {props: "src"}); if (avatar) avatar.props.src = this.getUserAvatar(recipientId); let userName = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {name: "EmptyMessageHeader"}); if (userName) { userName.props.children = BDFDB.ReactUtils.createElement("span", {children: name}); this.changeUserColor(userName.props.children, recipientId); } userName = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {name: "strong"}); if (userName) { userName.props.children = "@" + name; this.changeUserColor(userName, recipientId); } } } processMessage (e) { if (this.settings.places.chatWindow) { let header = e.instance.props.childrenHeader; if (header && header.props && header.props.message && this.shouldChangeInChat(header.props.message.channel_id)) { let data = changedUsers[header.props.message.author.id]; if (data) { let color1 = data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(header.props.message.channel_id) || {}).guild_id, header.props.message.author.id) || {}).colorString || data.color1; let message = new BDFDB.DiscordObjects.Message(Object.assign({}, header.props.message, {author: this.getUserData(header.props.message.author.id, true, false, header.props.message.author)})); if (color1) message.colorString = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); header.props.message = message; } } let content = e.instance.props.childrenMessageContent; if (content && content.type && content.type.type && content.props.message && this.shouldChangeInChat(content.props.message.channel_id)) { let data = changedUsers[content.props.message.author.id]; if (data) { let messageColor = data.color2 || (BDFDB.ObjectUtils.get(BDFDB.BDUtils.getPlugin("BetterRoleColors", true), "settings.modules.chat") && (data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(content.props.message.channel_id) || {}).guild_id, content.props.message.author.id) || {}).colorString || data.color1)); if (messageColor) { let message = new BDFDB.DiscordObjects.Message(Object.assign({}, content.props.message, {author: this.getUserData(content.props.message.author.id, true, false, content.props.message.author)})); message.colorString = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(messageColor) ? messageColor[0] : messageColor, "HEX"); content.props.message = message; } } } let repliedMessage = e.instance.props.childrenRepliedMessage; if (repliedMessage && repliedMessage.props && repliedMessage.props.children && repliedMessage.props.children.props && repliedMessage.props.children.props.referencedMessage && repliedMessage.props.children.props.referencedMessage.message && this.shouldChangeInChat(repliedMessage.props.children.props.referencedMessage.message.channel_id)) { let referenceMessage = repliedMessage.props.children.props.referencedMessage.message; let data = changedUsers[referenceMessage.author.id]; if (data) { let color1 = data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(referenceMessage.channel_id) || {}).guild_id, header.props.message.author.id) || {}).colorString || data.color1; let message = new BDFDB.DiscordObjects.Message(Object.assign({}, referenceMessage, {author: this.getUserData(referenceMessage.author.id, true, false, referenceMessage.author)})); if (color1) message.colorString = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); repliedMessage.props.children.props.referencedMessage = Object.assign({}, repliedMessage.props.children.props.referencedMessage, {message: message}); } } } } processMessageUsername (e) { if (!e.instance.props.message || !this.settings.places.chatWindow || !this.shouldChangeInChat(e.instance.props.message.channel_id)) return; const author = e.instance.props.userOverride || e.instance.props.message.author; let data = changedUsers[author.id]; if (!data) return; if (!e.returnvalue) { let color1 = data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id, author.id) || {}).colorString || data.color1; color1 = color1 && BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); if (e.instance.props.userOverride) e.instance.props.userOverride = this.getUserData(author.id) else { let message = new BDFDB.DiscordObjects.Message(Object.assign({}, e.instance.props.message, {author: this.getUserData(author.id, true, false, author)})); if (color1) message.colorString = color1; e.instance.props.message = message; } let member = BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id, author.id); e.instance.props.author = Object.assign({}, e.instance.props.author, { nick: this.getUserNick(e.instance.props.author.id, member && member.nick) || e.instance.props.author.nick, guildMemberAvatar: (data.removeIcon || data.url) ? null : e.instance.props.author.guildMemberAvatar, colorString: color1 || e.instance.props.author.colorString }); } else if (e.returnvalue.props.children) { if (data.color1) { let messageUsername = BDFDB.ReactUtils.findChild(e.returnvalue.props.children, {name: "Popout", props: [["className", BDFDB.disCN.messageusername]]}); if (messageUsername) { if (messageUsername.props && typeof messageUsername.props.children == "function") { let renderChildren = messageUsername.props.children; messageUsername.props.children = BDFDB.TimeUtils.suppress((...args) => { let renderedChildren = renderChildren(...args); this.changeUserColor(renderedChildren, author.id, {guildId: (BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id}); return renderedChildren; }, "Error in Children Render of MessageUsername!", this); } else this.changeUserColor(messageUsername, author.id, {guildId: (BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id}); } } let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "Popout"}); if (index > -1) this.injectBadge(children, author.id, (BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id, e.instance.props.compact ? index : (index + 1), { tagClass: e.instance.props.compact ? BDFDB.disCN.messagebottagcompact : BDFDB.disCN.messagebottagcozy, useRem: true }); } } processMessageContent (e) { if (e.instance.props.message && this.settings.places.chatWindow && this.shouldChangeInChat(e.instance.props.message.channel_id)) { if (!e.returnvalue) { if (!BDFDB.DiscordConstants.MessageTypeGroups.USER_MESSAGE.has(message.type)) { let message = new BDFDB.DiscordObjects.Message(Object.assign({}, e.instance.props.message, {author: this.getUserData(e.instance.props.message.author.id, true, false, e.instance.props.message.author)})); let data = changedUsers[e.instance.props.message.author.id]; if (data) { let color1 = data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id, e.instance.props.message.author.id) || {}).colorString || data.color1; if (color1) message.colorString = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); } e.instance.props.message = message; if (e.instance.props.children) e.instance.props.children.props.message = e.instance.props.message; } } else if (e.instance.props.message.state != BDFDB.DiscordConstants.MessageStates.SEND_FAILED) { let data = changedUsers[e.instance.props.message.author.id]; let messageColor = data && (data.color2 || (BDFDB.ObjectUtils.get(BDFDB.BDUtils.getPlugin("BetterRoleColors", true), "settings.modules.chat") && (data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.message.channel_id) || {}).guild_id, e.instance.props.message.author.id) || {}).colorString || data.color1))); if (messageColor) { if (BDFDB.ObjectUtils.is(messageColor)) e.returnvalue.props.children = BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextGradientElement, { gradient: BDFDB.ColorUtils.createGradient(messageColor), children: e.returnvalue.props.children }); else e.returnvalue.props.children = BDFDB.ReactUtils.createElement("span", { style: Object.assign({}, e.returnvalue.props.style, {color: BDFDB.ColorUtils.convert(messageColor, "RGBA")}), children: e.returnvalue.props.children }); } } } } processThreadMessageAccessoryMessage (e) { if (e.instance.props.message && this.settings.places.chatWindow && this.shouldChangeInChat(e.instance.props.message.channel_id)) e.instance.props.message = new BDFDB.DiscordObjects.Message(Object.assign({}, e.instance.props.message, {author: this.getUserData(e.instance.props.message.author.id)})); } processReactorsComponent (e) { if (this.settings.places.reactions && BDFDB.ArrayUtils.is(e.instance.props.reactors) && this.shouldChangeInChat(e.instance.props.channel.id)) { if (!e.returnvalue) { for (let i in e.instance.props.reactors) if (!BDFDB.LibraryStores.GuildMemberStore.getNick(e.instance.props.guildId, e.instance.props.reactors[i].id)) e.instance.props.reactors[i] = this.getUserData(e.instance.props.reactors[i].id, true, false, e.instance.props.reactors[i]); } else { let renderRow = e.returnvalue.props.renderRow; e.returnvalue.props.renderRow = (...args) => { let row = renderRow(...args); if (row && row.props && row.props.user && changedUsers[row.props.user.id]) { let type = row.type; row.type = (...args2) => { let result = type(...args2); let nickName = BDFDB.LibraryStores.GuildMemberStore.getNick(row.props.guildId, row.props.user.id) && BDFDB.ReactUtils.findChild(result, {props: [["className", BDFDB.disCN.messagereactionsmodalnickname]]}); if (nickName) { if (changedUsers[row.props.user.id].name) BDFDB.ReactUtils.setChild(nickName, changedUsers[row.props.user.id].name); this.changeUserColor(nickName, row.props.user.id); } return result; }; } return row; }; } } } processUserMention (e) { if (e.instance.props.userId && this.settings.places.mentions && changedUsers[e.instance.props.userId] && this.shouldChangeInChat(e.instance.props.channelId)) { if (typeof e.returnvalue.props.children == "function") { let renderChildren = e.returnvalue.props.children; e.returnvalue.props.children = BDFDB.TimeUtils.suppress((...args) => { let children = renderChildren(...args); this.changeMention(BDFDB.ReactUtils.findChild(children, {name: "Mention"}), changedUsers[e.instance.props.userId]); return children; }, "Error in Children Render of UserMention!", this); } else this.changeMention(BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Mention"}), changedUsers[e.instance.props.userId]); } } processRichUserMention (e) { if (e.instance.props.id && this.settings.places.mentions && changedUsers[e.instance.props.id] && this.shouldChangeInChat(e.instance.props.channel && e.instance.props.channel.id)) { let data = changedUsers[e.instance.props.id]; let tooltipChildren = BDFDB.ObjectUtils.get(e, "returnvalue.props.text.props.children"); if (tooltipChildren) { if (tooltipChildren[0] && tooltipChildren[0].props && tooltipChildren[0].props.user) tooltipChildren[0].props.user = this.getUserData(tooltipChildren[0].props.user.id); if (data.name && typeof tooltipChildren[1] == "string") tooltipChildren[1] = data.name; } if (data.name || data.color1) { if (typeof e.returnvalue.props.children == "function") { let renderChildren = e.returnvalue.props.children; e.returnvalue.props.children = BDFDB.TimeUtils.suppress((...args) => { let children = renderChildren(...args); this.changeMention(children, data); return children; }, "Error in Children Render of RichUserMention!", this); } else this.changeMention(e.returnvalue, data); } } } changeMention (mention, data) { if (!mention) return; if (data.name) { const changeMentionName = (child, name) => { if (!child) return; if (BDFDB.ArrayUtils.is(child)) for (let i in child) { if (typeof child[i] == "string" && child[i][0] == "@") { if (child[i] == "@") child[parseInt(i) + 1] = data.name; else child[i] = "@" + data.name; } else changeMentionName(child[i]); } else if (child.props && typeof child.props.children == "string" && child.props.children[0] == "@") child.props.children = "@" + data.name; else if (child.props && child.props.children) changeMentionName(child.props.children); }; changeMentionName(mention); } if (data.color1) { mention.props.color = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(data.color1) ? data.color1[0] : data.color1, "INT"); if (mention.props.children && mention.props.children.props) mention.props.children.props.color = mention.props.color; } } processChannelReply (e) { if (e.instance.props.reply && e.instance.props.reply.message && this.settings.places.chatWindow && this.shouldChangeInChat(e.instance.props.reply.message.channel_id)) { if (!e.returnvalue) { let message = new BDFDB.DiscordObjects.Message(Object.assign({}, e.instance.props.reply.message, {author: this.getUserData(e.instance.props.reply.message.author.id)})); let data = changedUsers[e.instance.props.reply.message.author.id]; if (data) { let color1 = data.color1 && data.useRoleColor && (BDFDB.LibraryStores.GuildMemberStore.getMember((BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.reply.message.channel_id) || {}).guild_id, e.instance.props.reply.message.author.id) || {}).colorString || data.color1; if (color1) message.colorString = BDFDB.ColorUtils.convert(BDFDB.ObjectUtils.is(color1) ? color1[0] : color1, "HEX"); } e.instance.props.reply = Object.assign({}, e.instance.props.reply, {message: message}); } else { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.messagereplyname]]}); if (userName) this.changeUserColor(userName, e.instance.props.reply.message.author.id); } } } processMemberListItem (e) { if (e.instance.props.user && this.settings.places.memberList && this.shouldChangeInChat()) { if (!e.returnvalue) { e.instance.props.user = this.getUserData(e.instance.props.user.id); let data = changedUsers[e.instance.props.user.id]; if (data) { if (data.name) { let member = BDFDB.LibraryStores.GuildMemberStore.getMember(e.instance.props.channel.guild_id, e.instance.props.user.id); e.instance.props.nick = this.getUserNick(e.instance.props.user.id, member && member.nick); } if (data.removeStatus || data.status || data.statusEmoji) { e.instance.props.activities = [].concat(e.instance.props.activities).filter(n => n.type != BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS); let activity = this.createCustomStatus(data); if (activity) e.instance.props.activities.unshift(activity); } } } else { this.changeUserColor(e.returnvalue.props.name, e.instance.props.user.id, {e: e, guildId: e.instance.props.channel.guild_id}); this.injectBadge(BDFDB.ObjectUtils.get(e.returnvalue, "props.decorators.props.children"), e.instance.props.user.id, BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), 2, { tagClass: BDFDB.disCN.bottagmember }); } } } processAuditLogs (e) { if (e.instance.props.logs && this.settings.places.guildSettings) { if (!BDFDB.PatchUtils.isPatched(this, e.instance, "renderUserQuickSelectItem")) BDFDB.PatchUtils.patch(this, e.instance, "renderUserQuickSelectItem", {after: e2 => {if (e2.methodArguments[0] && e2.methodArguments[0].user && changedUsers[e2.methodArguments[0].user.id]) { let userName = BDFDB.ReactUtils.findChild(e2.returnValue, {props: [["children", e2.methodArguments[0].label]]}); if (userName) { if (changedUsers[e2.methodArguments[0].user.id].name) userName.props.children = changedUsers[e2.methodArguments[0].user.id].name; this.changeUserColor(userName, e2.methodArguments[0].user.id); } let avatar = BDFDB.ReactUtils.findChild(e2.returnValue, {props: [["className", BDFDB.disCN.auditlogpopoutavatar]]}); if (avatar) avatar.props.src = this.getUserAvatar(e2.methodArguments[0].user.id); }}}, {force: true, noCache: true}); } } processGuildSettingsAuditLogEntry (e) { if (e.instance.props.log && this.settings.places.guildSettings) { if (e.instance.props.log.user) e.instance.props.log.user = this.getUserData(e.instance.props.log.user.id); if (e.instance.props.log.target && e.instance.props.log.targetType == "USER") e.instance.props.log.target = this.getUserData(e.instance.props.log.target.id); } } processGuildSettingsEmoji (e) { if (BDFDB.ArrayUtils.is(e.instance.props.emojis) && this.settings.places.guildSettings) { e.instance.props.emojis = [].concat(e.instance.props.emojis); for (let i in e.instance.props.emojis) e.instance.props.emojis[i] = Object.assign({}, e.instance.props.emojis[i], {user: this.getUserData(e.instance.props.emojis[i].user.id)}); } } processMemberCard (e) { if (e.instance.props.user && this.settings.places.guildSettings) e.instance.props.user = this.getUserData(e.instance.props.user.id); } processSettingsInvites (e) { if (BDFDB.ObjectUtils.is(e.instance.props.invites) && this.settings.places.guildSettings) { e.instance.props.invites = Object.assign({}, e.instance.props.invites); for (let id in e.instance.props.invites) e.instance.props.invites[id] = new BDFDB.DiscordObjects.Invite(Object.assign({}, e.instance.props.invites[id], {inviter: this.getUserData(e.instance.props.invites[id].inviter.id)})); } } processGuildSettingsBans (e) { if (BDFDB.ObjectUtils.is(e.instance.props.bans) && this.settings.places.guildSettings) { e.instance.props.bans = Object.assign({}, e.instance.props.bans); for (let id in e.instance.props.bans) e.instance.props.bans[id] = Object.assign({}, e.instance.props.bans[id], {user: this.getUserData(e.instance.props.bans[id].user.id)}); } } processInvitationCard (e) { if (e.instance.props.user && this.settings.places.inviteList) { if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id); else { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.invitemodalinviterowname]]}); if (userName) this.changeUserColor(userName, e.instance.props.user.id); } } } processPrivateChannelRecipientsInvitePopout (e) { if (BDFDB.ArrayUtils.is(e.instance.props.results) && this.settings.places.inviteList) { for (let result of e.instance.props.results) result.user = this.getUserData(result.user.id); } } processInviteModalUserRow (e) { if (e.instance.props.user && this.settings.places.inviteList) { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.searchpopoutddmaddnickname]]}); if (userName) this.changeUserColor(userName, e.instance.props.user.id); } } processTypingUsers (e) { if (BDFDB.ObjectUtils.is(e.instance.props.typingUsers) && Object.keys(e.instance.props.typingUsers).length && this.settings.places.typing) { let users = Object.keys(e.instance.props.typingUsers).filter(id => id != BDFDB.UserUtils.me.id).filter(id => !BDFDB.LibraryStores.RelationshipStore.isBlocked(id)).map(id => BDFDB.LibraryStores.UserStore.getUser(id)).filter(user => user); if (users.length) { let typingText = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.typingtext]]}); if (typingText && BDFDB.ArrayUtils.is(typingText.props.children)) for (let child of typingText.props.children) if (child.type == "strong") { let userId = (users.shift() || {}).id; if (userId) { let data = changedUsers[userId]; if (data && data.name) child.props.children = data.name; this.changeUserColor(child, userId); } } } } } processDirectMessage (e) { if (e.instance.props.channel && e.instance.props.channel.isDM() && this.settings.places.recentDms) { let recipientId = e.instance.props.channel.getRecipientId(); if (!recipientId || !changedUsers[recipientId]) return; e.instance.props.channelName = this.getUserData(recipientId).username; let avatar = BDFDB.ReactUtils.findChild(e.returnvalue, {filter: c => c && c.props && !isNaN(parseInt(c.props.id))}); if (avatar && typeof avatar.props.children == "function") { let childrenRender = avatar.props.children; avatar.props.children = BDFDB.TimeUtils.suppress((...args) => { let renderedChildren = childrenRender(...args); if (renderedChildren && renderedChildren.props) renderedChildren.props.icon = this.getUserAvatar(recipientId); return renderedChildren; }, "Error in Avatar Render of DirectMessage!", this); } } } processPrivateChannel (e) { if (e.instance.props.user && this.settings.places.dmsList && changedUsers[e.instance.props.user.id]) { if (!e.returnvalue) { let data = changedUsers[e.instance.props.user.id]; if (data.removeStatus || data.status || data.statusEmoji) { e.instance.props.activities = [].concat(e.instance.props.activities).filter(n => n.type != BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS); let activity = this.createCustomStatus(changedUsers[e.instance.props.user.id]); if (activity) e.instance.props.activities.unshift(activity); } } else { let wrapper = e.returnvalue && e.returnvalue.props.children && e.returnvalue.props.children.props && typeof e.returnvalue.props.children.props.children == "function" ? e.returnvalue.props.children : e.returnvalue; if (typeof wrapper.props.children == "function") { let childrenRender = wrapper.props.children; wrapper.props.children = BDFDB.TimeUtils.suppress((...args) => { let children = childrenRender(...args); this._processPrivateChannel(e.instance, children); return children; }, "Error in Children Render of PrivateChannel!", this); } else this._processPrivateChannel(e.instance, wrapper); } } } _processPrivateChannel (instance, returnvalue) { const wrapper = returnvalue.props.avatar ? returnvalue : BDFDB.ReactUtils.findChild(returnvalue, {props: ["avatar"]}); if (!wrapper) return; wrapper.props.name = BDFDB.ReactUtils.createElement("span", {children: this.getUserData(instance.props.user.id).username}); this.changeUserColor(wrapper.props.name, instance.props.user.id, {modify: BDFDB.ObjectUtils.extract(Object.assign({}, instance.props, instance.state), "hovered", "selected", "hasUnreadMessages", "muted")}); if (wrapper.props.avatar) wrapper.props.avatar.props.src = this.getUserAvatar(instance.props.user.id); wrapper.props.decorators = [wrapper.props.decorators].flat(10); this.injectBadge(wrapper.props.decorators, instance.props.user.id, null, 1); } processQuickSwitcherConnected (e) { if (e.returnvalue && e.returnvalue.props && e.returnvalue.props.query && (!e.returnvalue.props.queryMode || e.returnvalue.props.queryMode == BDFDB.DiscordConstants.AutocompleterResultTypes.USER)) { for (let id in changedUsers) if (changedUsers[id] && changedUsers[id].name && changedUsers[id].name.toLocaleLowerCase().indexOf(e.returnvalue.props.query.toLocaleLowerCase()) > -1 && !e.returnvalue.props.results.find(n => n.record && n.record.id == id && n.type == BDFDB.DiscordConstants.AutocompleterResultTypes.USER)) { let user = BDFDB.LibraryStores.UserStore.getUser(id); if (user) e.returnvalue.props.results.splice(1, 0, { comparator: `${user.username}#${user.discriminator}`, record: user, score: 30000, type: BDFDB.DiscordConstants.AutocompleterResultTypes.USER }); } } } processQuickSwitchUserResult (e) { if (e.instance.props.user && this.settings.places.quickSwitcher) { if (!e.returnvalue) e.instance.props.user = this.getUserData(e.instance.props.user.id); else { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.quickswitchresultmatch]]}); if (userName) { let data = changedUsers[e.instance.props.user.id]; if (data && data.name) userName.props.children = data.name; this.changeUserColor(userName, e.instance.props.user.id, {modify: BDFDB.ObjectUtils.extract(e.instance.props, "focused", "unread", "mentions")}); } } } } processSearchPopoutComponent (e) { if (BDFDB.ArrayUtils.is(BDFDB.ObjectUtils.get(e, "instance.props.resultsState.autocompletes")) && this.settings.places.searchPopout) { for (let autocomplete of e.instance.props.resultsState.autocompletes) if (autocomplete && BDFDB.ArrayUtils.is(autocomplete.results)) for (let result of autocomplete.results) if (result.user) result.user = this.getUserData(result.user.id); } } processSearchPopoutUserResult (e) { if (e.instance.props.result && e.instance.props.result.user && this.settings.places.searchPopout) { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.searchpopoutdisplayednick]]}); if (userName) { let data = changedUsers[e.instance.props.result.user.id]; if (data && data.name) userName.props.children = data.name; this.changeUserColor(userName, e.instance.props.result.user.id); } let avatar = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.searchpopoutdisplayavatar]]}); if (avatar) avatar.props.src = this.getUserAvatar(e.instance.props.result.user.id); } } processIncomingCallModal (e) { if (e.instance.props.channel && this.settings.places.dmCalls) { let user = BDFDB.LibraryStores.UserStore.getUser(e.instance.props.channel.id); if (!user) { let channel = BDFDB.LibraryStores.ChannelStore.getChannel(e.instance.props.channel.id); if (channel && channel.isDM()) user = BDFDB.LibraryStores.UserStore.getUser(channel.recipients[0]); } if (user) { let userName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.callincomingtitle]]}); if (userName) { let data = changedUsers[user.id]; if (data && data.name) userName.props.children = data.name; this.changeUserColor(userName, user.id); } let avatar = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "CallAvatar"}); if (avatar) avatar.props.src = this.getUserAvatar(user.id); } } } processRTCConnection (e) { if (e.instance.props.channel && e.instance.props.channel.isDM() && this.settings.places.recentDms && typeof e.returnvalue.props.children == "function") { let recipientId = e.instance.props.channel.getRecipientId(); let renderChildren = e.returnvalue.props.children; e.returnvalue.props.children = BDFDB.TimeUtils.suppress((...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; }, "Error in Children Render of RTCConnection!", this); } } processPrivateChannelCallParticipants (e) { if (BDFDB.ArrayUtils.is(e.instance.props.participants) && this.settings.places.dmCalls) { e.instance.props.participants = [].concat(e.instance.props.participants); for (let i in e.instance.props.participants) if (e.instance.props.participants[i] && e.instance.props.participants[i].user) e.instance.props.participants[i] = Object.assign({}, e.instance.props.participants[i], {user: this.getUserData(e.instance.props.participants[i].user.id)}); } } processParticipantsForSelectedParticipant (e) { if (this.settings.places.voiceChat) { let popout = BDFDB.ReactUtils.findChild(e.returnvalue, {name: "Popout"}); if (popout && typeof popout.props.children == "function") { let renderChildren = popout.props.children; popout.props.children = BDFDB.TimeUtils.suppress((...args) => { let renderedChildren = renderChildren(...args); for (let viewer of renderedChildren.props.children) viewer.props.src = this.getUserAvatar(viewer.key); return renderedChildren; }); } if (popout && typeof popout.props.renderPopout == "function") { let renderPopout = popout.props.renderPopout; popout.props.renderPopout = BDFDB.TimeUtils.suppress((...args) => { let renderedPopout = renderPopout(...args); renderedPopout.props.users = [].concat(renderedPopout.props.users); for (let i in renderedPopout.props.users) if (renderedPopout.props.users[i]) renderedPopout.props.users[i] = this.getUserData(renderedPopout.props.users[i].id); return renderedPopout; }); } } } processChannelCall (e) { if (BDFDB.ArrayUtils.is(e.instance.props.participants) && this.settings.places.voiceChat) { e.instance.props.participants = [].concat(e.instance.props.participants); for (let i in e.instance.props.participants) if (e.instance.props.participants[i] && e.instance.props.participants[i].user) e.instance.props.participants[i] = Object.assign({}, e.instance.props.participants[i], {user: this.getUserData(e.instance.props.participants[i].user.id)}); } } processChannelCallGrid (e) { this.processChannelCall(e); } processHorizontalVideoParticipants (e) { this.processChannelCall(e); } processPictureInPictureVideo (e) { if (e.instance.props.backgroundKey) { let user = BDFDB.LibraryStores.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) { 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); } } changeAppTitle () { let channel = BDFDB.LibraryStores.ChannelStore.getChannel(BDFDB.LibraryStores.SelectedChannelStore.getChannelId()); let title = document.head.querySelector("title"); if (title && channel && channel.isDM() && (document.location.href || "").indexOf(channel.id) > -1) { let user = BDFDB.LibraryStores.UserStore.getUser(channel.recipients[0]); if (user) BDFDB.DOMUtils.setText(title, "@" + this.getUserData(user.id, this.settings.places.appTitle).username); } } shouldChangeInChat (channelId) { if (this.settings.types.servers && this.settings.types.dms) return true; let channel = BDFDB.LibraryStores.ChannelStore.getChannel(channelId || BDFDB.LibraryStores.SelectedChannelStore.getChannelId()); let isDm = channel && (channel.isDM() || channel.isGroupDM()); if (channel && (this.settings.types.servers && !isDm || this.settings.types.dms && isDm)) return true; return false; } changeUserColor (child, userId, options = {}) { if (!BDFDB.ReactUtils.isValidElement(child)) return; let data = changedUsers[userId] || {}; if (data.color1) { let childProp = child.props.children ? "children" : "text"; let color1 = data.color1 && data.useRoleColor && options.guildId && (BDFDB.LibraryStores.GuildMemberStore.getMember(options.guildId, userId) || {}).colorString || data.color1; let fontColor = options.modify && !(data.useRoleColor && options.guildId) ? this.chooseColor(color1, options.modify) : color1; let fontGradient = BDFDB.ObjectUtils.is(fontColor); if (BDFDB.ObjectUtils.is(child.props.style)) delete child.props.style.color; if (child.props[childProp].props && BDFDB.LibraryStores.AccessibilityStore.roleStyle != "dot") delete child.props[childProp].props.color; child.props[childProp] = BDFDB.ReactUtils.createElement("span", { style: { color: fontGradient ? BDFDB.ColorUtils.convert(fontColor[0], "RGBA") : BDFDB.ColorUtils.convert(fontColor, "RGBA") }, children: fontGradient ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextGradientElement, { gradient: BDFDB.ColorUtils.createGradient(fontColor), children: child.props[childProp] }) : child.props[childProp] }); } } chooseColor (color, config = {}) { if (color) { if (BDFDB.ObjectUtils.is(config)) { if (config.mentions || config.focused || config.hovered || config.selected || config.unread || config.hasUnreadMessages || config.speaking) color = BDFDB.ColorUtils.change(color, 0.5); else if (config.muted || config.locked) color = BDFDB.ColorUtils.change(color, -0.5); } return color; } return null; } getUserData (userId, change = true, keepName = false, fallbackData) { let user = BDFDB.LibraryStores.UserStore.getUser(userId); if (!user && BDFDB.ObjectUtils.is(fallbackData) || user && BDFDB.ObjectUtils.is(fallbackData) && user.username != fallbackData.username) user = fallbackData; if (!user) return new BDFDB.DiscordObjects.User({}); let data = change && changedUsers[user.id]; if (data) { let newUserObject = {}, nativeObject = new BDFDB.DiscordObjects.User(user); for (let key in nativeObject) newUserObject[key] = nativeObject[key]; newUserObject.tag = nativeObject.tag; newUserObject.createdAt = nativeObject.createdAt; newUserObject.username = !keepName && data.name || nativeObject.username; newUserObject.usernameNormalized = !keepName && data.name && data.name.toLowerCase() || nativeObject.usernameNormalized; if (data.removeIcon) { newUserObject.avatar = null; newUserObject.avatarURL = null; newUserObject.getAvatarSource = _ => null; newUserObject.getAvatarURL = _ => null; newUserObject.guildMemberAvatars = {}; } else if (data.url) { newUserObject.avatar = data.url; newUserObject.avatarURL = data.url; newUserObject.getAvatarSource = _ => data.url; newUserObject.getAvatarURL = _ => data.url; newUserObject.guildMemberAvatars = {}; } if (data.removeBanner) { newUserObject.banner = null; newUserObject.bannerURL = null; newUserObject.getBannerSource = _ => null; newUserObject.getBannerURL = _ => null; } else if (data.banner) { newUserObject.banner = data.banner; newUserObject.bannerURL = data.banner; newUserObject.getBannerSource = _ => data.banner; newUserObject.getBannerURL = _ => data.banner; } return newUserObject; } return new BDFDB.DiscordObjects.User(user); } getUserNick (userId, nick, change = true) { let user = BDFDB.LibraryStores.UserStore.getUser(userId); if (!user) return ""; let data = change && changedUsers[user.id]; if (data) return (data.useServerNick && nick || data.name && [data.name, data.showServerNick && nick && `(${nick})` || data.showAccountName && user.username && `(${user.username})`].filter(n => n).join(" ")) || nick || ""; return ""; } getUserAvatar (userId, change = true) { let user = BDFDB.LibraryStores.UserStore.getUser(userId); if (!user) return ""; let data = change && changedUsers[user.id]; if (data) { if (data.removeIcon) return ""; else if (data.url) return data.url; } return BDFDB.LibraryModules.IconUtils.getUserAvatarURL(user); } injectBadge (children, userId, guildId, insertIndex, config = {}) { if (!BDFDB.ArrayUtils.is(children) || !userId) return; let data = changedUsers[userId]; if (data && data.tag) { let memberColor = data.ignoreTagColor && (BDFDB.LibraryStores.GuildMemberStore.getMember(guildId, userId) || {}).colorString; let fontColor = !config.inverted ? data.color4 : (memberColor || data.color3); let backgroundColor = !config.inverted ? (memberColor || data.color3) : data.color4; let fontGradient = BDFDB.ObjectUtils.is(fontColor); children.splice(insertIndex, 0, BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.BotTag, { className: config.tagClass, useRemSizes: config.useRem, invertColor: config.inverted, style: { background: BDFDB.ObjectUtils.is(backgroundColor) ? BDFDB.ColorUtils.createGradient(backgroundColor) : BDFDB.ColorUtils.convert(backgroundColor, "RGBA"), color: fontGradient ? BDFDB.ColorUtils.convert(fontColor[0], "RGBA") : BDFDB.ColorUtils.convert(fontColor, "RGBA") }, tag: fontGradient ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextGradientElement, { gradient: BDFDB.ColorUtils.createGradient(fontColor), children: data.tag }) : data.tag })); } } createCustomStatus (data) { return !BDFDB.ObjectUtils.is(data) || data.removeStatus ? null : { created_at: (new Date()).getTime().toString(), emoji: data.statusEmoji, id: "custom", name: "Custom Status", state: data.status, type: BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS } } openUserSettingsModal (user) { let data = changedUsers[user.id] || {}; let newData = Object.assign({}, data); let member = BDFDB.LibraryStores.GuildMemberStore.getMember(BDFDB.LibraryStores.SelectedGuildStore.getGuildId(), user.id) || {}; let activity = BDFDB.LibraryStores.PresenceStore.getApplicationActivity(user.id); let avatarInput, bannerInput, statusEmojiInput, statusInput, colorPicker3, colorPicker4; BDFDB.ModalUtils.open(this, { size: "LARGE", header: this.labels.modal_header, subHeader: member.nick || user.username, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ModalComponents.ModalTabContent, { tab: this.labels.modal_tabheader1, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.marginbottom8, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { className: BDFDB.disCN.marginbottom8, align: BDFDB.LibraryComponents.Flex.Align.CENTER, direction: BDFDB.LibraryComponents.Flex.Direction.HORIZONTAL, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.marginreset, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, children: this.labels.modal_username }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { value: data.name, placeholder: member.nick || user.username, autoFocus: true, onChange: value => newData.name = value }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { className: BDFDB.disCN.marginbottom20, justify: BDFDB.LibraryComponents.Flex.Justify.END, align: BDFDB.LibraryComponents.Flex.Align.CENTER, direction: BDFDB.LibraryComponents.Flex.Direction.HORIZONTAL, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: this.labels.modal_showaccountname, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.showAccountName, onChange: value => newData.showAccountName = value }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: this.labels.modal_showservernick, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.showServerNick, onChange: value => newData.showServerNick = value }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: this.labels.modal_useservernick, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.useServerNick, onChange: value => newData.useServerNick = value }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_usertag, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { value: data.tag, onChange: value => newData.tag = value }) }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.marginbottom20, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { className: BDFDB.disCN.marginbottom8, align: BDFDB.LibraryComponents.Flex.Align.CENTER, direction: BDFDB.LibraryComponents.Flex.Direction.HORIZONTAL, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.marginreset, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, children: this.labels.modal_useravatar }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: BDFDB.LanguageUtils.LanguageStrings.REMOVE, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.removeIcon, onChange: value => { newData.removeIcon = value; if (value) { delete avatarInput.props.success; delete avatarInput.props.errorMessage; avatarInput.props.disabled = true; BDFDB.ReactUtils.forceUpdate(avatarInput); } else { avatarInput.props.disabled = false; this.checkUrl(avatarInput.props.value, avatarInput).then(returnValue => newData.url = returnValue); } } }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { success: !data.removeIcon && data.url, maxLength: 100000000000000000000, value: data.url, placeholder: BDFDB.UserUtils.getAvatar(user.id), disabled: data.removeIcon, ref: instance => {if (instance) avatarInput = instance;}, onChange: (value, instance) => { this.checkUrl(value, instance).then(returnValue => newData.url = returnValue); } }) ] }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.marginbottom20, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { className: BDFDB.disCN.marginbottom8, align: BDFDB.LibraryComponents.Flex.Align.CENTER, direction: BDFDB.LibraryComponents.Flex.Direction.HORIZONTAL, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.marginreset, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, children: BDFDB.LanguageUtils.LanguageStrings.USER_SETTINGS_PROFILE_BANNER }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: BDFDB.LanguageUtils.LanguageStrings.REMOVE, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.removeBanner, onChange: value => { newData.removeBanner = value; if (value) { delete bannerInput.props.success; delete bannerInput.props.errorMessage; bannerInput.props.disabled = true; BDFDB.ReactUtils.forceUpdate(bannerInput); } else { bannerInput.props.disabled = false; this.checkUrl(bannerInput.props.value, bannerInput).then(returnValue => newData.banner = returnValue); } } }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { success: !data.removeBanner && data.banner, maxLength: 100000000000000000000, value: data.banner, placeholder: BDFDB.UserUtils.getBanner(user.id), ref: instance => {if (instance) bannerInput = instance;}, onChange: (value, instance) => { this.checkUrl(value, instance).then(returnValue => newData.banner = returnValue); } }) ] }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.marginbottom20, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { className: BDFDB.disCN.marginbottom8, align: BDFDB.LibraryComponents.Flex.Align.CENTER, direction: BDFDB.LibraryComponents.Flex.Direction.HORIZONTAL, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormTitle, { className: BDFDB.disCN.marginreset, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, children: BDFDB.LanguageUtils.LanguageStrings.CUSTOM_STATUS }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: BDFDB.LanguageUtils.LanguageStrings.REMOVE, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.removeStatus, onChange: value => { newData.removeStatus = value; statusInput.props.disabled = value; BDFDB.ReactUtils.forceUpdate(statusInput); } }) ] }), BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.emojiinputcontainer, children: [ BDFDB.ReactUtils.createElement("div", { className: BDFDB.disCN.emojiinputbuttoncontainer, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.EmojiPickerButton, { emoji: data.statusEmoji, allowManagedEmojis: true, allowManagedEmojisUsage: true, ref: instance => {if (instance) statusEmojiInput = instance;}, onSelect: value => newData.statusEmoji = value }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { inputClassName: BDFDB.disCN.emojiinput, maxLength: 100000000000000000000, value: data.status, placeholder: activity && activity.type == BDFDB.DiscordConstants.ActivityTypes.CUSTOM_STATUS && activity.state || "", disabled: data.removeStatus, ref: instance => {if (instance) statusInput = instance;}, onChange: value => newData.status = value }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Button, { size: BDFDB.LibraryComponents.Button.Sizes.NONE, look: BDFDB.LibraryComponents.Button.Looks.BLANK, className: BDFDB.disCN.emojiinputclearbutton, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, { className: BDFDB.disCN.emojiinputclearicon, name: BDFDB.LibraryComponents.SvgIcon.Names.CLOSE_CIRCLE }), onClick: _ => { newData.status = ""; newData.statusEmoji = null; statusInput.props.value = ""; delete statusEmojiInput.props.emoji; BDFDB.ReactUtils.forceUpdate(statusInput, statusEmojiInput); } }) ] }) ] }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ModalComponents.ModalTabContent, { tab: this.labels.modal_tabheader2, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_colorpicker1, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ColorSwatches, { color: data.color1, onColorChange: value => newData.color1 = value }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_colorpicker2, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ColorSwatches, { color: data.color2, onColorChange: value => newData.color2 = value }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 20, label: this.labels.modal_userolecolor, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.useRoleColor, onChange: value => newData.useRoleColor = value }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ModalComponents.ModalTabContent, { tab: this.labels.modal_tabheader3, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_colorpicker3, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ColorSwatches, { color: data.color3, disabled: data.ignoreTagColor, ref: instance => {if (instance) colorPicker3 = instance;}, onColorChange: value => newData.color3 = value }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_colorpicker4, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ColorSwatches, { color: data.color4, disabled: data.ignoreTagColor, ref: instance => {if (instance) colorPicker4 = instance;}, onColorChange: value => newData.color4 = value }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 20, label: this.labels.modal_ignoretagcolor, tag: BDFDB.LibraryComponents.FormComponents.FormTitle.Tags.H5, value: data.ignoreTagColor, onChange: value => { newData.ignoreTagColor = value; colorPicker3.props.disabled = value; colorPicker4.props.disabled = value; BDFDB.ReactUtils.forceUpdate(colorPicker3, colorPicker4); } }) ] }) ], buttons: [{ contents: BDFDB.LanguageUtils.LanguageStrings.SAVE, color: "BRAND", close: true, onClick: _ => { newData.url = !newData.removeIcon ? newData.url : ""; newData.status = !newData.removeStatus ? newData.status : ""; newData.statusEmoji = !newData.removeStatus ? newData.statusEmoji : null; let changed = false; if (Object.keys(newData).every(key => newData[key] == null || newData[key] == false) && (changed = true)) { BDFDB.DataUtils.remove(this, "users", user.id); } else if (!BDFDB.equals(newData, data) && (changed = true)) { BDFDB.DataUtils.save(newData, this, "users", user.id); } if (changed) this.forceUpdateAll(); } }] }); } checkUrl (url, instance) { return new Promise(callback => { BDFDB.TimeUtils.clear(instance.checkTimeout); url = url && url.trim(); if (!url || instance.props.disabled) { delete instance.props.success; delete instance.props.errorMessage; callback(""); BDFDB.ReactUtils.forceUpdate(instance); } else instance.checkTimeout = BDFDB.TimeUtils.timeout(_ => { BDFDB.LibraryRequires.request(url, {agentOptions: {rejectUnauthorized: false}}, (error, response, result) => { delete instance.checkTimeout; if (instance.props.disabled) { delete instance.props.success; delete instance.props.errorMessage; callback(""); } else if (response && response.headers["content-type"] && response.headers["content-type"].indexOf("image") != -1) { instance.props.success = true; delete instance.props.errorMessage; callback(url); } else { delete instance.props.success; instance.props.errorMessage = this.labels.modal_invalidurl; callback(""); } BDFDB.ReactUtils.forceUpdate(instance); }); }, 1000); }); } setLabelsByLanguage () { switch (BDFDB.LanguageUtils.getLanguage().id) { case "bg": // Bulgarian return { confirm_reset: "Наистина ли искате да нулирате този потребител?", confirm_resetall: "Наистина ли искате да нулирате всички потребители?", context_localusersettings: "Локални потребителски настройки", modal_colorpicker1: "Име Цвят", modal_colorpicker2: "Цвят на съобщението", modal_colorpicker3: "Цвят на маркера", modal_colorpicker4: "Цвят на шрифта", modal_header: "Локални потребителски настройки", modal_ignoretagcolor: "Използвайте Цвят на ролята", modal_invalidurl: "Невалиден адрес", modal_showaccountname: "Покажи име", modal_showservernick: "Показване на псевдонима", modal_tabheader1: "Потребител", modal_tabheader2: "Име Цвят", modal_tabheader3: "Цвят на маркера", modal_useravatar: "Аватар", modal_username: "Локално потребителско име", modal_userolecolor: "Не презаписвайте цвета на ролята", modal_usertag: "Етикет", modal_useservernick: "Не презаписвайте псевдонимите", submenu_resetsettings: "Нулиране на потребителя", submenu_usersettings: "Промяна на настройките" }; case "cs": // Czech return { confirm_reset: "Opravdu chcete tohoto uživatele resetovat?", confirm_resetall: "Opravdu chcete resetovat všechny uživatele?", context_localusersettings: "Místní nastavení uživatele", modal_colorpicker1: "Název Barva", modal_colorpicker2: "Barva zprávy", modal_colorpicker3: "Barva značky", modal_colorpicker4: "Barva fontu", modal_header: "Místní nastavení uživatele", modal_ignoretagcolor: "Použijte barvu role", modal_invalidurl: "Neplatná URL", modal_showaccountname: "Zobrazit jméno", modal_showservernick: "Zobrazit přezdívku", modal_tabheader1: "Uživatel", modal_tabheader2: "Název Barva", modal_tabheader3: "Barva značky", modal_useravatar: "Avatar", modal_username: "Místní uživatelské jméno", modal_userolecolor: "Nepřepisujte barvu role", modal_usertag: "Štítek", modal_useservernick: "Nepřepisujte přezdívky", submenu_resetsettings: "Obnovit uživatele", submenu_usersettings: "Změnit nastavení" }; case "da": // Danish return { confirm_reset: "Er du sikker på, at du vil nulstille denne bruger?", confirm_resetall: "Er du sikker på, at du vil nulstille alle brugere?", context_localusersettings: "Lokale brugerindstillinger", modal_colorpicker1: "Navnfarve", modal_colorpicker2: "Beskedfarve", modal_colorpicker3: "Tagfarve", modal_colorpicker4: "Skriftfarve", modal_header: "Lokale brugerindstillinger", modal_ignoretagcolor: "Brug rollefarve", modal_invalidurl: "Ugyldig URL", modal_showaccountname: "Vis navn", modal_showservernick: "Vis kaldenavn", modal_tabheader1: "Bruger", modal_tabheader2: "Navnfarve", modal_tabheader3: "Tagfarve", modal_useravatar: "Avatar", modal_username: "Lokalt brugernavn", modal_userolecolor: "Overskriv ikke rollefarven", modal_usertag: "Tag", modal_useservernick: "Overskriv ikke kælenavne", submenu_resetsettings: "Nulstil bruger", submenu_usersettings: "Ændre indstillinger" }; case "de": // German return { confirm_reset: "Möchtest du diesen Benutzer wirklich zurücksetzen?", confirm_resetall: "Möchtest du wirklich alle Benutzer zurücksetzen?", context_localusersettings: "Lokale Benutzereinstellungen", modal_colorpicker1: "Namensfarbe", modal_colorpicker2: "Nachrichtenfarbe", modal_colorpicker3: "Etikettarbe", modal_colorpicker4: "Schriftfarbe", modal_header: "Lokale Benutzereinstellungen", modal_ignoretagcolor: "Rollenfarbe verwenden", modal_invalidurl: "Ungültige URL", modal_showaccountname: "Name anzeigen", modal_showservernick: "Nicknamen anzeigen", modal_tabheader1: "Benutzer", modal_tabheader2: "Namensfarbe", modal_tabheader3: "Etikettfarbe", modal_useravatar: "Benutzerbild", modal_username: "Lokaler Benutzername", modal_userolecolor: "Rollenfarbe nicht überschreiben", modal_usertag: "Etikett", modal_useservernick: "Nicknamen nicht überschreiben", submenu_resetsettings: "Benutzer zurücksetzen", submenu_usersettings: "Einstellungen ändern" }; case "el": // Greek return { confirm_reset: "Είστε βέβαιοι ότι θέλετε να επαναφέρετε αυτόν τον χρήστη,", confirm_resetall: "Είστε βέβαιοι ότι θέλετε να επαναφέρετε όλους τους χρήστες,", context_localusersettings: "Ρυθμίσεις τοπικού χρήστη", modal_colorpicker1: "Χρώμα ονόματος", modal_colorpicker2: "Χρώμα μηνύματος", modal_colorpicker3: "Χρώμα ετικέτας", modal_colorpicker4: "Χρώμα γραμματοσειράς", modal_header: "Ρυθμίσεις τοπικού χρήστη", modal_ignoretagcolor: "Χρησιμοποιήστε το χρώμα του ρόλου", modal_invalidurl: "Μη έγκυρη διεύθυνση URL", modal_showaccountname: "Εμφάνιση ονόματος", modal_showservernick: "Εμφάνιση ψευδωνύμου", modal_tabheader1: "Χρήστης", modal_tabheader2: "Χρώμα ονόματος", modal_tabheader3: "Χρώμα ετικέτας", modal_useravatar: "Άβαταρ", modal_username: "Τοπικό όνομα χρήστη", modal_userolecolor: "Μην αντικαθιστάτε το χρώμα του ρόλου", modal_usertag: "Ετικέτα", modal_useservernick: "Μην αντικαθιστάτε ψευδώνυμα", submenu_resetsettings: "Επαναφορά χρήστη", submenu_usersettings: "Αλλαξε ρυθμίσεις" }; case "es": // Spanish return { confirm_reset: "¿Está seguro de que desea restablecer este usuario?", confirm_resetall: "¿Está seguro de que desea restablecer a todos los usuarios?", context_localusersettings: "Configuración de usuario local", modal_colorpicker1: "Color del nombre", modal_colorpicker2: "Color del mensaje", modal_colorpicker3: "Color de etiqueta", modal_colorpicker4: "Color de fuente", modal_header: "Configuración de usuario local", modal_ignoretagcolor: "Usar color de rol", modal_invalidurl: "URL invalida", modal_showaccountname: "Mostrar nombre", modal_showservernick: "Mostrar apodo", modal_tabheader1: "Usuario", modal_tabheader2: "Color del nombre", modal_tabheader3: "Color de etiqueta", modal_useravatar: "Avatar", modal_username: "Nombre de usuario local", modal_userolecolor: "No sobrescriba el color de la función", modal_usertag: "Etiqueta", modal_useservernick: "No sobrescriba los apodos", submenu_resetsettings: "Restablecer usuario", submenu_usersettings: "Cambiar ajustes" }; case "fi": // Finnish return { confirm_reset: "Haluatko varmasti nollata tämän käyttäjän?", confirm_resetall: "Haluatko varmasti nollata kaikki käyttäjät?", context_localusersettings: "Paikalliset käyttäjäasetukset", modal_colorpicker1: "Nimen väri", modal_colorpicker2: "Viestin väri", modal_colorpicker3: "Tagin väri", modal_colorpicker4: "Fontin väri", modal_header: "Paikalliset käyttäjäasetukset", modal_ignoretagcolor: "Käytä rooliväriä", modal_invalidurl: "Virheellinen URL", modal_showaccountname: "Näytä nimi", modal_showservernick: "Näytä lempinimi", modal_tabheader1: "Käyttäjä", modal_tabheader2: "Nimen väri", modal_tabheader3: "Tagin väri", modal_useravatar: "Hahmo", modal_username: "Paikallinen käyttäjätunnus", modal_userolecolor: "Älä korvaa roolin väriä", modal_usertag: "Tag", modal_useservernick: "Älä korvaa lempinimiä", submenu_resetsettings: "Nollaa käyttäjä", submenu_usersettings: "Vaihda asetuksia" }; case "fr": // French return { confirm_reset: "Êtes-vous sûr de vouloir réinitialiser cet utilisateur?", confirm_resetall: "Voulez-vous vraiment réinitialiser tous les utilisateurs?", context_localusersettings: "Paramètres locaux de l'utilisateur", modal_colorpicker1: "Couleur du nom", modal_colorpicker2: "Couleur du message", modal_colorpicker3: "Couleur de l'étiquette", modal_colorpicker4: "Couleur de la police", modal_header: "Paramètres locaux de l'utilisateur", modal_ignoretagcolor: "Utiliser la couleur du rôle", modal_invalidurl: "URL invalide", modal_showaccountname: "Afficher le nom", modal_showservernick: "Afficher le surnom", modal_tabheader1: "Utilisateur", modal_tabheader2: "Couleur du nom", modal_tabheader3: "Couleur de l'étiquette", modal_useravatar: "Avatar", modal_username: "Nom local d'utilisateur", modal_userolecolor: "Ne pas écraser la couleur du rôle", modal_usertag: "Marque", modal_useservernick: "Ne pas écraser les surnoms", submenu_resetsettings: "Réinitialiser l'utilisateur", submenu_usersettings: "Modifier les paramètres" }; case "hi": // Hindi return { confirm_reset: "क्या आप वाकई इस उपयोगकर्ता को रीसेट करना चाहते हैं?", confirm_resetall: "क्या आप वाकई सभी उपयोगकर्ताओं को रीसेट करना चाहते हैं?", context_localusersettings: "स्थानीय उपयोगकर्ता सेटिंग्स", modal_colorpicker1: "नाम रंग", modal_colorpicker2: "संदेश रंग", modal_colorpicker3: "टैग रंग", modal_colorpicker4: "लिपि का रंग", modal_header: "स्थानीय उपयोगकर्ता सेटिंग्स", modal_ignoretagcolor: "भूमिका रंग का प्रयोग करें", modal_invalidurl: "असामान्य यूआरएल", modal_showaccountname: "नाम दिखाएं", modal_showservernick: "उपनाम दिखाएं", modal_tabheader1: "उपयोगकर्ता", modal_tabheader2: "नाम रंग", modal_tabheader3: "टैग रंग", modal_useravatar: "अवतार", modal_username: "स्थानीय उपयोगकर्ता नाम", modal_userolecolor: "भूमिका रंग को अधिलेखित न करें", modal_usertag: "टैग", modal_useservernick: "उपनामों को अधिलेखित न करें", submenu_resetsettings: "उपयोगकर्ता को रीसेट करें", submenu_usersettings: "सेटिंग्स परिवर्तित करना" }; case "hr": // Croatian return { confirm_reset: "Jeste li sigurni da želite resetirati ovog korisnika?", confirm_resetall: "Jeste li sigurni da želite resetirati sve korisnike?", context_localusersettings: "Postavke lokalnog korisnika", modal_colorpicker1: "Naziv Boja", modal_colorpicker2: "Boja poruke", modal_colorpicker3: "Oznaka u boji", modal_colorpicker4: "Boja fonta", modal_header: "Postavke lokalnog korisnika", modal_ignoretagcolor: "Koristite boju uloga", modal_invalidurl: "Neispravna poveznica", modal_showaccountname: "Prikaži ime", modal_showservernick: "Prikaži nadimak", modal_tabheader1: "Korisnik", modal_tabheader2: "Naziv Boja", modal_tabheader3: "Oznaka u boji", modal_useravatar: "Avatar", modal_username: "Lokalno korisničko ime", modal_userolecolor: "Nemojte prebrisati boju uloge", modal_usertag: "Označiti", modal_useservernick: "Ne prepisujte nadimke", submenu_resetsettings: "Resetiraj korisnika", submenu_usersettings: "Promijeniti postavke" }; case "hu": // Hungarian return { confirm_reset: "Biztosan vissza akarja állítani ezt a felhasználót?", confirm_resetall: "Biztosan vissza akarja állítani az összes felhasználót?", context_localusersettings: "Helyi felhasználói beállítások", modal_colorpicker1: "Név színe", modal_colorpicker2: "Üzenet színe", modal_colorpicker3: "Címke színe", modal_colorpicker4: "Betű szín", modal_header: "Helyi felhasználói beállítások", modal_ignoretagcolor: "Használja a Szerepszínt", modal_invalidurl: "Érvénytelen URL", modal_showaccountname: "Név megjelenítése", modal_showservernick: "Becenév megjelenítése", modal_tabheader1: "Felhasználó", modal_tabheader2: "Név színe", modal_tabheader3: "Címke színe", modal_useravatar: "Avatar", modal_username: "Helyi felhasználónév", modal_userolecolor: "Ne írja felül a Szerepszínt", modal_usertag: "Címke", modal_useservernick: "Ne írja felül a beceneveket", submenu_resetsettings: "Felhasználó visszaállítása", submenu_usersettings: "Beállítások megváltoztatása" }; case "it": // Italian return { confirm_reset: "Sei sicuro di voler reimpostare questo utente?", confirm_resetall: "Sei sicuro di voler reimpostare tutti gli utenti?", context_localusersettings: "Impostazioni utente locale", modal_colorpicker1: "Colore nome", modal_colorpicker2: "Colore messaggio", modal_colorpicker3: "Colore tag", modal_colorpicker4: "Colore del carattere", modal_header: "Impostazioni utente locale", modal_ignoretagcolor: "Usa colore ruolo", modal_invalidurl: "URL non valido", modal_showaccountname: "Mostra nome", modal_showservernick: "Mostra soprannome", modal_tabheader1: "Utente", modal_tabheader2: "Nome Colore", modal_tabheader3: "Colore tag", modal_useravatar: "Avatar", modal_username: "Nome utente locale", modal_userolecolor: "Non sovrascrivere il colore del ruolo", modal_usertag: "Etichetta", modal_useservernick: "Non sovrascrivere i soprannomi", submenu_resetsettings: "Reimposta utente", submenu_usersettings: "Cambia impostazioni" }; case "ja": // Japanese return { confirm_reset: "このユーザーをリセットしてもよろしいですか?", confirm_resetall: "すべてのユーザーをリセットしてもよろしいですか?", context_localusersettings: "ローカルユーザー設定", modal_colorpicker1: "名前の色", modal_colorpicker2: "メッセージの色", modal_colorpicker3: "タグの色", modal_colorpicker4: "フォントの色", modal_header: "ローカルユーザー設定", modal_ignoretagcolor: "役割の色を使用する", modal_invalidurl: "無効なURL", modal_showaccountname: "名前を表示", modal_showservernick: "ニックネームを表示", modal_tabheader1: "ユーザー", modal_tabheader2: "名前の色", modal_tabheader3: "タグの色", modal_useravatar: "アバター", modal_username: "ローカルユーザー名", modal_userolecolor: "役割の色を上書きしないでください", modal_usertag: "鬼ごっこ", modal_useservernick: "ニックネームを上書きしないでください", submenu_resetsettings: "ユーザーのリセット", submenu_usersettings: "設定を変更する" }; case "ko": // Korean return { confirm_reset: "이 사용자를 재설정 하시겠습니까?", confirm_resetall: "모든 사용자를 재설정 하시겠습니까?", context_localusersettings: "로컬 사용자 설정", modal_colorpicker1: "이름 색상", modal_colorpicker2: "메시지 색상", modal_colorpicker3: "태그 색상", modal_colorpicker4: "글자 색", modal_header: "로컬 사용자 설정", modal_ignoretagcolor: "역할 색상 사용", modal_invalidurl: "잘못된 URL", modal_showaccountname: "이름 표시", modal_showservernick: "닉네임 표시", modal_tabheader1: "사용자", modal_tabheader2: "이름 색상", modal_tabheader3: "태그 색상", modal_useravatar: "화신", modal_username: "로컬 사용자 이름", modal_userolecolor: "역할 색상을 덮어 쓰지 마십시오.", modal_usertag: "꼬리표", modal_useservernick: "별명을 덮어 쓰지 마십시오", submenu_resetsettings: "사용자 재설정", submenu_usersettings: "설정 변경" }; case "lt": // Lithuanian return { confirm_reset: "Ar tikrai norite iš naujo nustatyti šį naudotoją?", confirm_resetall: "Ar tikrai norite iš naujo nustatyti visus naudotojus?", context_localusersettings: "Vietinio vartotojo nustatymai", modal_colorpicker1: "Pavadinimo spalva", modal_colorpicker2: "Pranešimo spalva", modal_colorpicker3: "Žymos spalva", modal_colorpicker4: "Šrifto spalva", modal_header: "Vietinio vartotojo nustatymai", modal_ignoretagcolor: "Naudokite vaidmens spalvą", modal_invalidurl: "Neteisingas URL", modal_showaccountname: "Rodyti pavadinimą", modal_showservernick: "Rodyti slapyvardį", modal_tabheader1: "Vartotojas", modal_tabheader2: "Pavadinimo spalva", modal_tabheader3: "Žymos spalva", modal_useravatar: "Avataras", modal_username: "Vietinis vartotojo vardas", modal_userolecolor: "Neperrašykite vaidmens spalvos", modal_usertag: "Žyma", modal_useservernick: "Neperrašykite slapyvardžių", submenu_resetsettings: "Iš naujo nustatyti vartotoją", submenu_usersettings: "Pakeisti nustatymus" }; case "nl": // Dutch return { confirm_reset: "Weet u zeker dat u deze gebruiker wilt resetten?", confirm_resetall: "Weet u zeker dat u alle gebruikers wilt resetten?", context_localusersettings: "Lokale gebruikersinstellingen", modal_colorpicker1: "Naamkleur", modal_colorpicker2: "Berichtkleur", modal_colorpicker3: "Tagkleur", modal_colorpicker4: "Letterkleur", modal_header: "Lokale gebruikersinstellingen", modal_ignoretagcolor: "Gebruik rolkleur", modal_invalidurl: "Ongeldige URL", modal_showaccountname: "Toon naam", modal_showservernick: "Bijnaam weergeven", modal_tabheader1: "Gebruiker", modal_tabheader2: "Naamkleur", modal_tabheader3: "Tagkleur", modal_useravatar: "Avatar", modal_username: "Lokale gebruikersnaam", modal_userolecolor: "Overschrijf de rolkleur niet", modal_usertag: "Label", modal_useservernick: "Overschrijf geen bijnamen", submenu_resetsettings: "Gebruiker resetten", submenu_usersettings: "Instellingen veranderen" }; case "no": // Norwegian return { confirm_reset: "Er du sikker på at du vil tilbakestille denne brukeren?", confirm_resetall: "Er du sikker på at du vil tilbakestille alle brukere?", context_localusersettings: "Lokale brukerinnstillinger", modal_colorpicker1: "Navnfarge", modal_colorpicker2: "Meldingfarge", modal_colorpicker3: "Merkefarge", modal_colorpicker4: "Skriftfarge", modal_header: "Lokale brukerinnstillinger", modal_ignoretagcolor: "Bruk rollefarge", modal_invalidurl: "Ugyldig URL", modal_showaccountname: "Vis navn", modal_showservernick: "Vis kallenavn", modal_tabheader1: "Bruker", modal_tabheader2: "Navnfarge", modal_tabheader3: "Merkefarge", modal_useravatar: "Avatar", modal_username: "Lokalt brukernavn", modal_userolecolor: "Ikke skriv rollefargen", modal_usertag: "Stikkord", modal_useservernick: "Ikke overskriv kallenavn", submenu_resetsettings: "Tilbakestill bruker", submenu_usersettings: "Endre innstillinger" }; case "pl": // Polish return { confirm_reset: "Czy na pewno chcesz zresetować tego użytkownika?", confirm_resetall: "Czy na pewno chcesz zresetować wszystkich użytkowników?", context_localusersettings: "Ustawienia użytkownika lokalnego", modal_colorpicker1: "Nazwa Kolor", modal_colorpicker2: "Kolor wiadomości", modal_colorpicker3: "Kolor tagu", modal_colorpicker4: "Kolor czcionki", modal_header: "Ustawienia użytkownika lokalnego", modal_ignoretagcolor: "Użyj koloru roli", modal_invalidurl: "Nieprawidłowy URL", modal_showaccountname: "Pokaż nazwę", modal_showservernick: "Pokaż pseudonim", modal_tabheader1: "Użytkownik", modal_tabheader2: "Nazwa Kolor", modal_tabheader3: "Kolor tagu", modal_useravatar: "Awatara", modal_username: "Lokalna nazwa użytkownika", modal_userolecolor: "Nie zastępuj koloru roli", modal_usertag: "Etykietka", modal_useservernick: "Nie nadpisuj pseudonimów", submenu_resetsettings: "Resetuj użytkownika", submenu_usersettings: "Zmień ustawienia" }; case "pt-BR": // Portuguese (Brazil) return { confirm_reset: "Tem certeza de que deseja redefinir este usuário?", confirm_resetall: "Tem certeza de que deseja redefinir todos os usuários?", context_localusersettings: "Configurações de usuário local", modal_colorpicker1: "Cor do nome", modal_colorpicker2: "Cor da Mensagem", modal_colorpicker3: "Cor da tag", modal_colorpicker4: "Cor da fonte", modal_header: "Configurações de usuário local", modal_ignoretagcolor: "Use a cor da função", modal_invalidurl: "URL inválida", modal_showaccountname: "Mostrar nome", modal_showservernick: "Mostrar apelido", modal_tabheader1: "Do utilizador", modal_tabheader2: "Cor do Nome", modal_tabheader3: "Cor da tag", modal_useravatar: "Avatar", modal_username: "Nome de usuário local", modal_userolecolor: "Não sobrescreva a Cor da Função", modal_usertag: "Tag", modal_useservernick: "Não sobrescrever apelidos", submenu_resetsettings: "Reiniciar usuário", submenu_usersettings: "Mudar configurações" }; case "ro": // Romanian return { confirm_reset: "Sigur doriți să resetați acest utilizator?", confirm_resetall: "Sigur doriți să resetați toți utilizatorii?", context_localusersettings: "Setări locale ale utilizatorului", modal_colorpicker1: "Culoare nume", modal_colorpicker2: "Culoarea mesajului", modal_colorpicker3: "Culoare etichetă", modal_colorpicker4: "Culoarea fontului", modal_header: "Setări locale ale utilizatorului", modal_ignoretagcolor: "Utilizați culoarea rolului", modal_invalidurl: "URL invalid", modal_showaccountname: "Afișează numele", modal_showservernick: "Afișează porecla", modal_tabheader1: "Utilizator", modal_tabheader2: "Culoare nume", modal_tabheader3: "Culoare etichetă", modal_useravatar: "Avatar", modal_username: "Nume utilizator local", modal_userolecolor: "Nu suprascrieți culoarea rolului", modal_usertag: "Etichetă", modal_useservernick: "Nu suprascrieți porecle", submenu_resetsettings: "Resetați utilizatorul", submenu_usersettings: "Schimbă setările" }; case "ru": // Russian return { confirm_reset: "Вы уверены, что хотите сбросить этого пользователя?", confirm_resetall: "Вы уверены, что хотите сбросить всех пользователей?", context_localusersettings: "Настройки локального пользователя", modal_colorpicker1: "Цвет имени", modal_colorpicker2: "Цвет сообщения", modal_colorpicker3: "Цвет метки", modal_colorpicker4: "Цвет шрифта", modal_header: "Настройки локального пользователя", modal_ignoretagcolor: "Использовать цвет роли", modal_invalidurl: "Неверная ссылка", modal_showaccountname: "Показать имя", modal_showservernick: "Показать ник", modal_tabheader1: "Пользователь", modal_tabheader2: "Цвет имени", modal_tabheader3: "Цвет метки", modal_useravatar: "Аватар", modal_username: "Локальное имя пользователя", modal_userolecolor: "Не перезаписывайте цвет роли", modal_usertag: "Тег", modal_useservernick: "Не перезаписывать никнеймы", submenu_resetsettings: "Сбросить пользователя", submenu_usersettings: "Изменить настройки" }; case "sv": // Swedish return { confirm_reset: "Är du säker på att du vill återställa den här användaren?", confirm_resetall: "Är du säker på att du vill återställa alla användare?", context_localusersettings: "Lokala användarinställningar", modal_colorpicker1: "Namnfärg", modal_colorpicker2: "Meddelandefärg", modal_colorpicker3: "Taggfärg", modal_colorpicker4: "Fontfärg", modal_header: "Lokala användarinställningar", modal_ignoretagcolor: "Använd rollfärg", modal_invalidurl: "Ogiltig URL", modal_showaccountname: "Visa namn", modal_showservernick: "Visa smeknamn", modal_tabheader1: "Användare", modal_tabheader2: "Namnfärg", modal_tabheader3: "Taggfärg", modal_useravatar: "Avatar", modal_username: "Lokalt användarnamn", modal_userolecolor: "Skriv inte över rollfärgen", modal_usertag: "Märka", modal_useservernick: "Skriv inte över smeknamn", submenu_resetsettings: "Återställ användare", submenu_usersettings: "Ändra inställningar" }; case "th": // Thai return { confirm_reset: "แน่ใจไหมว่าต้องการรีเซ็ตผู้ใช้นี้", confirm_resetall: "แน่ใจไหมว่าต้องการรีเซ็ตผู้ใช้ทั้งหมด", context_localusersettings: "การตั้งค่าผู้ใช้ภายใน", modal_colorpicker1: "ชื่อสี", modal_colorpicker2: "สีข้อความ", modal_colorpicker3: "สีแท็ก", modal_colorpicker4: "สีตัวอักษร", modal_header: "การตั้งค่าผู้ใช้ภายใน", modal_ignoretagcolor: "ใช้สีของบทบาท", modal_invalidurl: "URL ไม่ถูกต้อง", modal_showaccountname: "แสดงชื่อ", modal_showservernick: "แสดงชื่อเล่น", modal_tabheader1: "ผู้ใช้", modal_tabheader2: "ชื่อสี", modal_tabheader3: "สีแท็ก", modal_useravatar: "สัญลักษณ์", modal_username: "ชื่อผู้ใช้ท้องถิ่น", modal_userolecolor: "อย่าเขียนทับสีของบทบาท", modal_usertag: "แท็ก", modal_useservernick: "อย่าเขียนทับชื่อเล่น", submenu_resetsettings: "รีเซ็ตผู้ใช้", submenu_usersettings: "เปลี่ยนการตั้งค่า" }; case "tr": // Turkish return { confirm_reset: "Bu Kullanıcıyı sıfırlamak istediğinizden emin misiniz?", confirm_resetall: "Tüm Kullanıcıları sıfırlamak istediğinizden emin misiniz?", context_localusersettings: "Yerel Kullanıcı Ayarları", modal_colorpicker1: "İsim Rengi", modal_colorpicker2: "Mesaj Rengi", modal_colorpicker3: "Etiket Rengi", modal_colorpicker4: "Yazı rengi", modal_header: "Yerel Kullanıcı Ayarları", modal_ignoretagcolor: "Rol Rengini Kullan", modal_invalidurl: "Geçersiz URL", modal_showaccountname: "İsim göster", modal_showservernick: "Takma adı göster", modal_tabheader1: "Kullanıcı", modal_tabheader2: "İsim Rengi", modal_tabheader3: "Etiket Rengi", modal_useravatar: "Avatar", modal_username: "Yerel Kullanıcı Adı", modal_userolecolor: "Rol Renginin üzerine yazmayın", modal_usertag: "Etiket", modal_useservernick: "Takma adların üzerine yazmayın", submenu_resetsettings: "Kullanıcıyı Sıfırla", submenu_usersettings: "Ayarları değiştir" }; case "uk": // Ukrainian return { confirm_reset: "Ви впевнені, що хочете скинути налаштування цього користувача?", confirm_resetall: "Ви впевнені, що хочете скинути налаштування всіх користувачів?", context_localusersettings: "Налаштування локального користувача", modal_colorpicker1: "Назва Колір", modal_colorpicker2: "Колір повідомлення", modal_colorpicker3: "Колір тегу", modal_colorpicker4: "Колір шрифту", modal_header: "Налаштування локального користувача", modal_ignoretagcolor: "Використовуйте колір ролі", modal_invalidurl: "Недійсна URL-адреса", modal_showaccountname: "Показати ім'я", modal_showservernick: "Показати псевдонім", modal_tabheader1: "Користувач", modal_tabheader2: "Назва Колір", modal_tabheader3: "Колір тегу", modal_useravatar: "Аватар", modal_username: "Локальне ім’я користувача", modal_userolecolor: "Не перезаписуйте колір ролі", modal_usertag: "Позначка", modal_useservernick: "Не перезаписуйте псевдоніми", submenu_resetsettings: "Скинути налаштування користувача", submenu_usersettings: "Змінити налаштування" }; case "vi": // Vietnamese return { confirm_reset: "Bạn có chắc chắn muốn đặt lại Người dùng này không?", confirm_resetall: "Bạn có chắc chắn muốn đặt lại tất cả Người dùng không?", context_localusersettings: "Cài đặt người dùng cục bộ", modal_colorpicker1: "Tên màu", modal_colorpicker2: "Màu tin nhắn", modal_colorpicker3: "Màu thẻ", modal_colorpicker4: "Màu phông chữ", modal_header: "Cài đặt người dùng cục bộ", modal_ignoretagcolor: "Sử dụng màu vai trò", modal_invalidurl: "URL không hợp lệ", modal_showaccountname: "Hiện tên", modal_showservernick: "Hiển thị biệt hiệu", modal_tabheader1: "Người dùng", modal_tabheader2: "Tên màu", modal_tabheader3: "Màu thẻ", modal_useravatar: "Hình đại diện", modal_username: "Tên người dùng cục bộ", modal_userolecolor: "Không ghi đè Màu vai trò", modal_usertag: "Nhãn", modal_useservernick: "Không ghi đè biệt hiệu", submenu_resetsettings: "Đặt lại người dùng", submenu_usersettings: "Thay đổi cài đặt" }; case "zh-CN": // Chinese (China) return { confirm_reset: "您确定要重置此用户吗?", confirm_resetall: "您确定要重置所有用户吗?", context_localusersettings: "本地用户设置", modal_colorpicker1: "名称颜色", modal_colorpicker2: "讯息颜色", modal_colorpicker3: "标签颜色", modal_colorpicker4: "字体颜色", modal_header: "本地用户设置", modal_ignoretagcolor: "使用角色颜色", modal_invalidurl: "无效的网址", modal_showaccountname: "显示名称", modal_showservernick: "显示昵称", modal_tabheader1: "用户", modal_tabheader2: "名称颜色", modal_tabheader3: "标签颜色", modal_useravatar: "头像", modal_username: "本地用户名", modal_userolecolor: "不要覆盖角色颜色", modal_usertag: "标签", modal_useservernick: "不要覆盖昵称", submenu_resetsettings: "重置用户", submenu_usersettings: "更改设置" }; case "zh-TW": // Chinese (Taiwan) return { confirm_reset: "您確定要重置此用戶嗎?", confirm_resetall: "您確定要重置所有用戶嗎?", context_localusersettings: "本地用戶設置", modal_colorpicker1: "名稱顏色", modal_colorpicker2: "訊息顏色", modal_colorpicker3: "標籤顏色", modal_colorpicker4: "字體顏色", modal_header: "本地用戶設置", modal_ignoretagcolor: "使用角色顏色", modal_invalidurl: "無效的網址", modal_showaccountname: "顯示名稱", modal_showservernick: "顯示暱稱", modal_tabheader1: "用戶", modal_tabheader2: "名稱顏色", modal_tabheader3: "標籤顏色", modal_useravatar: "頭像", modal_username: "本地用戶名", modal_userolecolor: "不要覆蓋角色顏色", modal_usertag: "標籤", modal_useservernick: "不要覆蓋暱稱", submenu_resetsettings: "重置用戶", submenu_usersettings: "更改設置" }; default: // English return { confirm_reset: "Are you sure you want to reset this User?", confirm_resetall: "Are you sure you want to reset all Users?", context_localusersettings: "Local User Settings", modal_colorpicker1: "Name Color", modal_colorpicker2: "Message Color", modal_colorpicker3: "Tag Color", modal_colorpicker4: "Font Color", modal_header: "Local User Settings", modal_ignoretagcolor: "Use Role Color", modal_invalidurl: "Invalid URL", modal_showaccountname: "Show Name", modal_showservernick: "Show Nickname", modal_tabheader1: "User", modal_tabheader2: "Name Color", modal_tabheader3: "Tag Color", modal_useravatar: "Avatar", modal_username: "Local Username", modal_userolecolor: "Do not overwrite the Role Color", modal_usertag: "Tag", modal_useservernick: "Do not overwrite Nicknames", submenu_resetsettings: "Reset User", submenu_usersettings: "Change Settings" }; } } }; })(window.BDFDB_Global.PluginUtils.buildPlugin(changeLog)); })();