/** * @name EditServers * @author DevilBro * @authorId 278543574059057154 * @version 2.4.3 * @description Allows you to locally edit Servers * @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/EditServers/ * @updateUrl https://mwittrien.github.io/BetterDiscordAddons/Plugins/EditServers/EditServers.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 () { BdApi.Net.fetch("https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js").then(r => { if (!r || r.status != 200) throw new Error(); else return r.text(); }).then(b => { if (!b) throw new Error(); else return require("fs").writeFile(require("path").join(BdApi.Plugins.folder, "0BDFDB.plugin.js"), b, _ => BdApi.showToast("Finished downloading BDFDB Library", {type: "success"})); }).catch(error => { 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 changedGuilds = {}; return class EditServers extends Plugin { onLoad () { this.defaults = { general: { addOriginalTooltip: {value: true, description: "Hovering over a changed Server Header shows the original Name as Tooltip"}, }, places: { guildList: {value: true, description: "Server List"}, guildHeader: {value: true, description: "Server Header"}, invites: {value: true, description: "Server Invites"}, chat: {value: true, description: "Chat (Welcome Message, etc.)"}, mutualGuilds: {value: true, description: "Mutual Servers"}, recentMentions: {value: true, description: "Recent Mentions Popout"}, quickSwitcher: {value: true, description: "Quick Switcher"} } }; this.modulePatches = { before: [ "ChannelsList", "GuildHeader", "GuildIconWrapper", "GuildItem", "InviteGuildName", "QuickSwitchChannelResult", "QuickSwitchGuildResult" ], after: [ "BlobMask", "DefaultChannelEmptyMessage", "GuildHeader", "GuildIcon", "GuildIconWrapper", "GuildItem", "UserProfileMutualGuilds", "RecentsChannelHeader" ] }; this.patchPriority = 7; this.css = ` ${BDFDB.dotCN.inviteguildicon} { background-size: cover; object-fit: cover; } `; } onStart () { BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.IconUtils, "getGuildBannerURL", {instead: e => { let guild = BDFDB.LibraryStores.GuildStore.getGuild(e.methodArguments[0].id); if (guild) { let data = changedGuilds[guild.id]; if (data && data.banner && !data.removeBanner) return data.banner; } return e.callOriginalMethod(); }}); BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.QuerySearchUtils, "queryGuilds", {after: e => { if (!e.methodArguments[0].query) return; for (let id in changedGuilds) if (changedGuilds[id] && changedGuilds[id].name && changedGuilds[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.GUILD)) { let guild = BDFDB.LibraryStores.GuildStore.getGuild(id); if (guild) e.returnValue.push({ comparator: guild.name, record: guild, score: 30000, sortable: guild.name.toLocaleLowerCase(), type: BDFDB.DiscordConstants.AutocompleterResultTypes.GUILD }); } }}); this.forceUpdateAll(); } onStop () { this.forceUpdateAll(); } getSettingsPanel (collapseStates = {}) { let settingsPanel; return settingsPanel = BDFDB.PluginUtils.createSettingsPanel(this, { collapseStates: collapseStates, children: _ => { let settingsItems = []; settingsItems.push(Object.keys(this.defaults.general).map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, { type: "Switch", plugin: this, keys: ["general", key], label: this.defaults.general[key].description, value: this.settings.general[key] }))); settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelList, { title: "Change Servers 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.SettingsItem, { type: "Button", color: BDFDB.LibraryComponents.Button.Colors.RED, label: "Reset all Servers", onClick: _ => BDFDB.ModalUtils.confirm(this, this.labels.confirm_resetall, _ => { BDFDB.DataUtils.remove(this, "servers"); this.forceUpdateAll();; }), children: BDFDB.LanguageUtils.LanguageStrings.RESET })); return settingsItems; } }); } onSettingsClosed () { if (this.SettingsUpdated) { delete this.SettingsUpdated; this.forceUpdateAll(); } } forceUpdateAll () { changedGuilds = BDFDB.DataUtils.load(this, "servers"); BDFDB.DiscordUtils.rerenderAll(); } onGuildContextMenu (e) { if (!e.instance.props.guild) return; 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: BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { label: this.labels.context_localserversettings, 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_serversettings, id: BDFDB.ContextMenuUtils.createItemId(this.name, "settings-change"), action: _ => this.openGuildSettingsModal(e.instance.props.guild.id) }), 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: !changedGuilds[e.instance.props.guild.id], action: event => { let remove = _ => { BDFDB.DataUtils.remove(this, "servers", e.instance.props.guild.id); this.forceUpdateAll(true); }; if (event.shiftKey) remove(); else BDFDB.ModalUtils.confirm(this, this.labels.confirm_reset, remove); } }) ] }) }) })); } processGuildItem (e) { if (!this.settings.places.guildList || !BDFDB.GuildUtils.is(e.instance.props.guild) || !e.instance.props.guild.joinedAt) return; if (!e.returnvalue) e.instance.props.guild = this.getGuildData(e.instance.props.guild.id); else { let data = changedGuilds[e.instance.props.guild.id]; if (data && (data.color3 || data.color4)) { let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: ["GuildTooltip", "BDFDB_TooltipContainer"]}); if (index > -1) children[index] = BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, { tooltipConfig: { type: "right", guild: e.instance.props.guild, list: true, offset: 12, backgroundColor: data.color3, fontColor: data.color4 }, children: children[index].props.children }); } } } processBlobMask (e) { if (!this.settings.places.guildList) return; let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "NavItem"}); if (index == -1 || !children[index].props.to || !children[index].props.to.pathname) return; let guild = BDFDB.LibraryStores.GuildStore.getGuild((children[index].props.to.pathname.split("/channels/")[1] || "").split("/")[0]); if (!guild || !changedGuilds[guild.id]) return; if (changedGuilds[guild.id].shortName) children[index].props.name = changedGuilds[guild.id].shortName.split("").join(" "); else if (changedGuilds[guild.id].name && changedGuilds[guild.id].ignoreCustomName) children[index].props.name = guild.name; } processGuildIcon (e) { this.processGuildIconWrapper(e); } processGuildIconWrapper (e) { if (!BDFDB.GuildUtils.is(e.instance.props.guild) || !changedGuilds[e.instance.props.guild.id] || !e.instance.props.guild.joinedAt) return; let change = true; if (e.instance.props.className && e.instance.props.className.indexOf(BDFDB.disCN.guildfolderguildicon) > -1) change = this.settings.places.guildList; else if (e.instance.props.className && e.instance.props.className.indexOf(BDFDB.disCN.listavatar) > -1) change = this.settings.places.mutualGuilds; if (change) e.instance.props.guild = this.getGuildData(e.instance.props.guild.id); } processUserProfileMutualGuilds (e) { if (!this.settings.places.mutualGuilds || !e.returnvalue.props.children || !e.returnvalue.props.children.length) return; for (let row of e.returnvalue.props.children) if (row && row.props && row.props.guild) row.props.guild = this.getGuildData(row.props.guild.id); } processQuickSwitchGuildResult (e) { if (this.settings.places.quickSwitcher && e.instance.props.guild) e.instance.props.guild = this.getGuildData(e.instance.props.guild.id); } processQuickSwitchChannelResult (e) { if (this.settings.places.quickSwitcher && e.instance.props.channel && e.instance.props.channel.guild_id) e.instance.props.children.props.children = this.getGuildData(e.instance.props.channel.guild_id).name; } processRecentsChannelHeader (e) { if (!this.settings.places.recentMentions || !e.instance.props.channel || !e.instance.props.channel.guild_id || !changedGuilds[e.instance.props.channel.guild_id] || !changedGuilds[e.instance.props.channel.guild_id].name) return; let guild = BDFDB.LibraryStores.GuildStore.getGuild(e.instance.props.channel.guild_id); if (!guild) return; let guildName = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.recentmentionsguildname]]}); if (guildName && typeof guildName.props.children == "string") guildName.props.children = guildName.props.children.replace(guild.name, changedGuilds[e.instance.props.channel.guild_id].name); } processChannelsList (e) { if (!this.settings.places.guildHeader || !e.instance.props.guild || !changedGuilds[e.instance.props.guild.id]) return; let newGuild = this.getGuildData(e.instance.props.guild.id); if (newGuild.banner) { e.instance.props.bannerVisible = true; e.instance.props.guildBanner = newGuild.banner; } else { e.instance.props.bannerVisible = false; e.instance.props.guildBanner = null; } } processGuildHeader (e) { if (!this.settings.places.guildHeader || !e.instance.props.guild || !changedGuilds[e.instance.props.guild.id]) return; let newGuild = this.getGuildData(e.instance.props.guild.id); if (newGuild.banner) { e.instance.props.bannerVisible = true; e.instance.props.guildBanner = newGuild.banner; } else { e.instance.props.bannerVisible = false; e.instance.props.guildBanner = null; } let oldName = (BDFDB.LibraryStores.GuildStore.getGuild(e.instance.props.guild.id) || {}).name; if (e.returnvalue && this.settings.general.addOriginalTooltip && oldName != newGuild.name) { let name = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.guildheadername]]}); if (name) name.props.children = newGuild.name; e.returnvalue.props.children[0] = BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, { text: oldName, children: e.returnvalue.props.children[0], tooltipConfig: {type: "right"} }); } } processInviteGuildName (e) { if (this.settings.places.invites && e.instance.props.guild && e.instance.props.guild.joinedAt) e.instance.props.guild = this.getGuildData(e.instance.props.guild.id); } processDefaultChannelEmptyMessage (e) { if (!this.settings.places.chat || !e.instance.props.channel || !changedGuilds[e.instance.props.channel.guild_id] || !changedGuilds[e.instance.props.channel.guild_id].name) return; let name = (BDFDB.LibraryStores.GuildStore.getGuild(e.instance.props.channel.guild_id) || {}).name; let guildName = name && BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.defaultchannelwelcometitle]]}); if (guildName) for (let child of guildName.props.children) if (child && child.props && child.props.children && child.props.children[0] == name) child.props.children[0] = changedGuilds[e.instance.props.channel.guild_id].name; } getGuildData (guildId, change = true) { let guild = BDFDB.LibraryStores.GuildStore.getGuild(guildId); if (!guild) return new BDFDB.DiscordObjects.Guild({}); let data = change && changedGuilds[guild.id]; if (data) { let nativeObject = new BDFDB.DiscordObjects.Guild(guild); let newGuildObject = BDFDB.ObjectUtils.copy(nativeObject); newGuildObject.toString = _ => newGuildObject.name; newGuildObject.name = data.name || nativeObject.name; newGuildObject.acronym = data.shortName && data.shortName.replace(/\s/g, "") || BDFDB.StringUtils.getAcronym(!data.ignoreCustomName && data.name || nativeObject.name); if (data.removeIcon) { newGuildObject.icon = null; newGuildObject.getIconURL = _ => {return null;}; } else if (data.url) { newGuildObject.icon = data.url; newGuildObject.getIconURL = _ => {return data.url;}; } if (data.removeBanner) newGuildObject.banner = null; else if (data.banner) newGuildObject.banner = data.banner; return newGuildObject; } return new BDFDB.DiscordObjects.Guild(guild); } openGuildSettingsModal (guildId) { let guild = BDFDB.LibraryStores.GuildStore.getGuild(guildId); if (!guild) return; let data = changedGuilds[guild.id] || {}; let newData = Object.assign({}, data); let nameInput, acronymInput, iconInput, bannerInput; BDFDB.ModalUtils.open(this, { size: "MEDIUM", header: this.labels.modal_header, subHeader: guild.name, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ModalComponents.ModalTabContent, { tab: this.labels.modal_tabheader1, children: [ BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_guildname, className: BDFDB.disCN.marginbottom20, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { value: data.name, placeholder: guild.name, autoFocus: true, ref: instance => {if (instance) nameInput = instance;}, onChange: value => { newData.name = value; if (!newData.ignoreCustomName) { acronymInput.props.placeholder = value && BDFDB.StringUtils.getAcronym(value) || guild.acronym; BDFDB.ReactUtils.forceUpdate(acronymInput); } } }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, { title: this.labels.modal_guildacronym, className: BDFDB.disCN.marginbottom8, children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { value: data.shortName, ref: instance => {if (instance) acronymInput = instance;}, placeholder: !data.ignoreCustomName && data.name && BDFDB.StringUtils.getAcronym(data.name) || guild.acronym, onChange: value => {newData.shortName = value;} }) }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", className: BDFDB.disCN.marginbottom20, label: this.labels.modal_ignorecustomname, tag: BDFDB.LibraryComponents.FormComponents.FormTags.H5, value: data.ignoreCustomName, onChange: value => { newData.ignoreCustomName = value; acronymInput.props.placeholder = !value && newData.name && BDFDB.StringUtils.getAcronym(newData.name) || guild.acronym; BDFDB.ReactUtils.forceUpdate(acronymInput); } }), 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.FormTags.H5, children: BDFDB.LanguageUtils.LibraryStrings.guildicon }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: BDFDB.LanguageUtils.LanguageStrings.REMOVE, tag: BDFDB.LibraryComponents.FormComponents.FormTags.H5, value: data.removeIcon, onChange: value => { newData.removeIcon = value; if (value) { delete iconInput.props.success; delete iconInput.props.errorMessage; iconInput.props.disabled = true; BDFDB.ReactUtils.forceUpdate(iconInput); } else { iconInput.props.disabled = false; this.checkUrl(iconInput.props.value, iconInput).then(returnValue => newData.url = returnValue); } } }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { success: !data.removeIcon && data.url, maxLength: 100000000000000000000, value: data.url, placeholder: BDFDB.GuildUtils.getIcon(guild.id), disabled: data.removeIcon, ref: instance => {if (instance) iconInput = 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.FormTags.H5, children: BDFDB.LanguageUtils.LibraryStrings.guildbanner }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, { type: "Switch", margin: 0, grow: 0, label: BDFDB.LanguageUtils.LanguageStrings.REMOVE, tag: BDFDB.LibraryComponents.FormComponents.FormTags.H5, value: data.removeBanner && guild.id != "410787888507256842", disabled: guild.id == "410787888507256842", 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.url = returnValue); } } }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, { success: !data.removeBanner && data.banner, maxLength: 100000000000000000000, value: data.banner, placeholder: BDFDB.GuildUtils.getBanner(guild.id), disabled: data.removeBanner || guild.id == "410787888507256842", ref: instance => {if (instance) bannerInput = instance;}, onChange: (value, instance) => { this.checkUrl(value, instance).then(returnValue => newData.banner = returnValue); } }) ] }) ] }), BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.ModalComponents.ModalTabContent, { tab: this.labels.modal_tabheader2, 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, 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, onColorChange: value => newData.color4 = value }) ] }) ] }) ], buttons: [{ contents: BDFDB.LanguageUtils.LanguageStrings.SAVE, color: "BRAND", close: true, onClick: _ => { newData.url = !newData.removeIcon ? newData.url : ""; newData.removeBanner = newData.removeBanner && guild.id != "410787888507256842"; newData.banner = !newData.removeBanner ? newData.banner : ""; let changed = false; if (Object.keys(newData).every(key => newData[key] == null || newData[key] == false) && (changed = true)) { BDFDB.DataUtils.remove(this, "servers", guild.id); } else if (!BDFDB.equals(newData, data) && (changed = true)) { BDFDB.DataUtils.save(newData, this, "servers", guild.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 if (url.indexOf("data:") == 0) { instance.props.success = true; delete instance.props.errorMessage; callback(url); } 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); }); } setBanner (id, data) { data = data || {}; let guild = BDFDB.LibraryStores.GuildStore.getGuild(id); if (!guild) return; if (guild.EditServersCachedBanner === undefined) guild.EditServersCachedBanner = guild.banner; guild.banner = data.removeBanner ? null : (data.banner || guild.EditServersCachedBanner); } setLabelsByLanguage () { switch (BDFDB.LanguageUtils.getLanguage().id) { case "bg": // Bulgarian return { confirm_reset: "Наистина ли искате да нулирате този сървър?", confirm_resetall: "Наистина ли искате да нулирате всички сървъри?", context_localserversettings: "Настройки на локалния сървър", modal_colorpicker1: "Цвят на иконата", modal_colorpicker2: "Цвят на шрифта", modal_colorpicker3: "Цвят на подсказка", modal_colorpicker4: "Цвят на шрифта", modal_guildacronym: "Локален сървър Акроним", modal_guildname: "Име на локален сървър", modal_header: "Настройки на локалния сървър", modal_ignorecustomname: "Използвайте оригиналното име на сървъра за съкращението на сървъра", modal_invalidurl: "Невалиден адрес", modal_tabheader1: "Сървър", modal_tabheader2: "Цвят на подсказка", submenu_resetsettings: "Нулиране на сървъра", submenu_serversettings: "Промяна на настройките" }; case "da": // Danish return { confirm_reset: "Er du sikker på, at du vil nulstille denne server?", confirm_resetall: "Er du sikker på, at du vil nulstille alle servere?", context_localserversettings: "Lokale serverindstillinger", modal_colorpicker1: "Ikonfarve", modal_colorpicker2: "Skrift farve", modal_colorpicker3: "Værktøjstip farve", modal_colorpicker4: "Skrift farve", modal_guildacronym: "Lokal server akronym", modal_guildname: "Lokalt servernavn", modal_header: "Lokale serverindstillinger", modal_ignorecustomname: "Brug det originale servernavn til serverakronymet", modal_invalidurl: "Ugyldig URL", modal_tabheader1: "Server", modal_tabheader2: "Værktøjstip farve", submenu_resetsettings: "Nulstil server", submenu_serversettings: "Ændre indstillinger" }; case "de": // German return { confirm_reset: "Möchtest du diesen Server wirklich zurücksetzen?", confirm_resetall: "Möchtest du wirklich alle Server zurücksetzen?", context_localserversettings: "Lokale Servereinstellungen", modal_colorpicker1: "Symbolfarbe", modal_colorpicker2: "Schriftfarbe", modal_colorpicker3: "Tooltipfarbe", modal_colorpicker4: "Schriftfarbe", modal_guildacronym: "Lokales Serverakronym", modal_guildname: "Lokaler Servername", modal_header: "Lokale Servereinstellungen", modal_ignorecustomname: "Verwenden Sie den ursprünglichen Servernamen für das Serverakronym", modal_invalidurl: "Ungültige URL", modal_tabheader1: "Server", modal_tabheader2: "Tooltipfarbe", submenu_resetsettings: "Server zurücksetzen", submenu_serversettings: "Einstellungen ändern" }; case "el": // Greek return { confirm_reset: "Είστε βέβαιοι ότι θέλετε να επαναφέρετε αυτόν τον διακομιστή;", confirm_resetall: "Είστε βέβαιοι ότι θέλετε να επαναφέρετε όλους τους διακομιστές;", context_localserversettings: "Ρυθμίσεις διακομιστή (τοπικά)", modal_colorpicker1: "Χρώμα εικονιδίου", modal_colorpicker2: "Χρώμα γραμματοσειράς", modal_colorpicker3: "Χρώμα επεξήγησης εργαλείου", modal_colorpicker4: "Χρώμα γραμματοσειράς", modal_guildacronym: "Τοπικό αρκτικόλεξο διακομιστή", modal_guildname: "Τοπικό όνομα διακομιστή", modal_header: "Ρυθμίσεις διακομιστή (τοπικά)", modal_ignorecustomname: "Χρησιμοποιήστε το αρχικό όνομα διακομιστή για το αρκτικόλεξο διακομιστή", modal_invalidurl: "Μη έγκυρη διεύθυνση URL", modal_tabheader1: "Διακομιστής", modal_tabheader2: "Χρώμα επεξήγησης εργαλείου", submenu_resetsettings: "Επαναφορά διακομιστή", submenu_serversettings: "Αλλαγή ρυθμίσεων" }; case "es": // Spanish return { confirm_reset: "¿Está seguro de que desea restablecer este servidor?", confirm_resetall: "¿Está seguro de que desea restablecer todos los servidores?", context_localserversettings: "Configuración del servidor local", modal_colorpicker1: "Color del icono", modal_colorpicker2: "Color de fuente", modal_colorpicker3: "Color de información sobre herramientas", modal_colorpicker4: "Color de fuente", modal_guildacronym: "Acrónimo del servidor local", modal_guildname: "Nombre del servidor local", modal_header: "Configuración del servidor local", modal_ignorecustomname: "Utilice el nombre del servidor original para el acrónimo del servidor", modal_invalidurl: "URL invalida", modal_tabheader1: "Servidor", modal_tabheader2: "Color de información sobre herramientas", submenu_resetsettings: "Restablecer servidor", submenu_serversettings: "Cambiar ajustes" }; case "fi": // Finnish return { confirm_reset: "Haluatko varmasti nollata tämän palvelimen?", confirm_resetall: "Haluatko varmasti nollata kaikki palvelimet?", context_localserversettings: "Paikallisen palvelimen asetukset", modal_colorpicker1: "Kuvakkeen väri", modal_colorpicker2: "Fontin väri", modal_colorpicker3: "Työkaluvihjeen väri", modal_colorpicker4: "Fontin väri", modal_guildacronym: "Paikallisen palvelimen lyhenne", modal_guildname: "Paikallisen palvelimen nimi", modal_header: "Paikallisen palvelimen asetukset", modal_ignorecustomname: "Käytä palvelimen lyhenteessä alkuperäistä palvelimen nimeä", modal_invalidurl: "Virheellinen URL", modal_tabheader1: "Palvelin", modal_tabheader2: "Työkaluvihjeen väri", submenu_resetsettings: "Nollaa palvelin", submenu_serversettings: "Vaihda asetuksia" }; case "fr": // French return { confirm_reset: "Êtes-vous sûr de vouloir réinitialiser ce serveur?", confirm_resetall: "Voulez-vous vraiment réinitialiser tous les serveurs?", context_localserversettings: "Paramètres locaux du serveur", modal_colorpicker1: "Couleur de l'icône", modal_colorpicker2: "Couleur de la police", modal_colorpicker3: "Couleur de l'info-bulle", modal_colorpicker4: "Couleur de la police", modal_guildacronym: "Acronyme local du serveur", modal_guildname: "Nom local du serveur", modal_header: "Paramètres locaux du serveur", modal_ignorecustomname: "Utilisez le nom de serveur d'origine pour l'acronyme de serveur", modal_invalidurl: "URL invalide", modal_tabheader1: "Serveur", modal_tabheader2: "Couleur de l'info-bulle", submenu_resetsettings: "Réinitialiser le serveur", submenu_serversettings: "Modifier les paramètres" }; case "hr": // Croatian return { confirm_reset: "Jeste li sigurni da želite resetirati ovaj poslužitelj?", confirm_resetall: "Jeste li sigurni da želite resetirati sve poslužitelje?", context_localserversettings: "Postavke lokalnog poslužitelja", modal_colorpicker1: "Ikona Boja", modal_colorpicker2: "Boja fonta", modal_colorpicker3: "Boja opisa", modal_colorpicker4: "Boja fonta", modal_guildacronym: "Lokalni poslužitelj kratica", modal_guildname: "Naziv lokalnog poslužitelja", modal_header: "Postavke lokalnog poslužitelja", modal_ignorecustomname: "Koristite izvorno ime poslužitelja za kraticu poslužitelja", modal_invalidurl: "Neispravna poveznica", modal_tabheader1: "Poslužitelj", modal_tabheader2: "Boja opisa", submenu_resetsettings: "Resetiraj poslužitelj", submenu_serversettings: "Promijeniti postavke" }; case "hu": // Hungarian return { confirm_reset: "Biztosan visszaállítja ezt a szervert?", confirm_resetall: "Biztosan visszaállítja az összes szervert?", context_localserversettings: "Helyi kiszolgáló beállításai", modal_colorpicker1: "Ikon színe", modal_colorpicker2: "Betű szín", modal_colorpicker3: "Tooltip Color", modal_colorpicker4: "Betű szín", modal_guildacronym: "Helyi szerver betűszó", modal_guildname: "Helyi kiszolgáló neve", modal_header: "Helyi kiszolgáló beállításai", modal_ignorecustomname: "A kiszolgáló rövidítéshez használja az eredeti kiszolgáló nevet", modal_invalidurl: "Érvénytelen URL", modal_tabheader1: "Szerver", modal_tabheader2: "Tooltip Color", submenu_resetsettings: "Reset Server", submenu_serversettings: "Beállítások megváltoztatása" }; case "it": // Italian return { confirm_reset: "Sei sicuro di voler reimpostare questo server?", confirm_resetall: "Sei sicuro di voler ripristinare tutti i server?", context_localserversettings: "Impostazioni locale del server", modal_colorpicker1: "Colore dell'icona", modal_colorpicker2: "Colore del carattere", modal_colorpicker3: "Colore della descrizione comando", modal_colorpicker4: "Colore del carattere", modal_guildacronym: "Acronimo locale del server", modal_guildname: "Nome locale server", modal_header: "Impostazioni locale del server", modal_ignorecustomname: "Utilizzare il nome del server originale per l'acronimo del server", modal_invalidurl: "URL non valido", modal_tabheader1: "Server", modal_tabheader2: "Colore della descrizione comando", submenu_resetsettings: "Reimposta server", submenu_serversettings: "Cambia impostazioni" }; case "ja": // Japanese return { confirm_reset: "このサーバーをリセットしてもよろしいですか?", confirm_resetall: "すべてのサーバーをリセットしてもよろしいですか?", context_localserversettings: "ローカルサーバー設定", modal_colorpicker1: "アイコンの色", modal_colorpicker2: "フォントの色", modal_colorpicker3: "ツールチップの色", modal_colorpicker4: "フォントの色", modal_guildacronym: "ローカルサーバーの頭字語", modal_guildname: "ローカルサーバー名", modal_header: "ローカルサーバー設定", modal_ignorecustomname: "サーバーの頭字語には元のサーバー名を使用します", modal_invalidurl: "無効なURL", modal_tabheader1: "サーバ", modal_tabheader2: "ツールチップの色", submenu_resetsettings: "サーバーのリセット", submenu_serversettings: "設定を変更する" }; case "ko": // Korean return { confirm_reset: "이 서버를 재설정 하시겠습니까?", confirm_resetall: "모든 서버를 재설정 하시겠습니까?", context_localserversettings: "로컬 서버 설정", modal_colorpicker1: "아이콘 색상", modal_colorpicker2: "글자 색", modal_colorpicker3: "툴팁 색상", modal_colorpicker4: "글자 색", modal_guildacronym: "로컬 서버 약어", modal_guildname: "로컬 서버 이름", modal_header: "로컬 서버 설정", modal_ignorecustomname: "서버 약어에 원래 서버 이름 사용", modal_invalidurl: "잘못된 URL", modal_tabheader1: "섬기는 사람", modal_tabheader2: "툴팁 색상", submenu_resetsettings: "서버 재설정", submenu_serversettings: "설정 변경" }; case "lt": // Lithuanian return { confirm_reset: "Ar tikrai norite iš naujo nustatyti šį serverį?", confirm_resetall: "Ar tikrai norite iš naujo nustatyti visus serverius?", context_localserversettings: "Vietinio serverio nustatymai", modal_colorpicker1: "Piktogramos spalva", modal_colorpicker2: "Šrifto spalva", modal_colorpicker3: "Patarimo spalva", modal_colorpicker4: "Šrifto spalva", modal_guildacronym: "Vietinio serverio santrumpa", modal_guildname: "Vietinio serverio pavadinimas", modal_header: "Vietinio serverio nustatymai", modal_ignorecustomname: "Serverio akronimui naudokite originalų serverio pavadinimą", modal_invalidurl: "Neteisingas URL", modal_tabheader1: "Serveris", modal_tabheader2: "Patarimo spalva", submenu_resetsettings: "Iš naujo nustatyti serverį", submenu_serversettings: "Pakeisti nustatymus" }; case "nl": // Dutch return { confirm_reset: "Weet u zeker dat u deze server opnieuw wilt instellen?", confirm_resetall: "Weet u zeker dat u alle servers wilt resetten?", context_localserversettings: "Lokale serverinstellingen", modal_colorpicker1: "Icoonkleur", modal_colorpicker2: "Letterkleur", modal_colorpicker3: "Tooltipkleur", modal_colorpicker4: "Letterkleur", modal_guildacronym: "Lokale serveracroniem", modal_guildname: "Lokale servernaam", modal_header: "Lokale serverinstellingen", modal_ignorecustomname: "Gebruik de oorspronkelijke servernaam voor het serveracroniem", modal_invalidurl: "Ongeldige URL", modal_tabheader1: "Server", modal_tabheader2: "Tooltipkleur", submenu_resetsettings: "Reset server", submenu_serversettings: "Instellingen veranderen" }; case "no": // Norwegian return { confirm_reset: "Er du sikker på at du vil tilbakestille denne serveren?", confirm_resetall: "Er du sikker på at du vil tilbakestille alle serverne?", context_localserversettings: "Lokale serverinnstillinger", modal_colorpicker1: "Ikonfarge", modal_colorpicker2: "Skriftfarge", modal_colorpicker3: "Verktøytipsfarge", modal_colorpicker4: "Skriftfarge", modal_guildacronym: "Lokal serverakronymet", modal_guildname: "Lokalt servernavn", modal_header: "Lokale serverinnstillinger", modal_ignorecustomname: "Bruk det originale servernavnet for serverakronymet", modal_invalidurl: "Ugyldig URL", modal_tabheader1: "Server", modal_tabheader2: "Verktøytipsfarge", submenu_resetsettings: "Tilbakestill server", submenu_serversettings: "Endre innstillinger" }; case "pl": // Polish return { confirm_reset: "Czy na pewno chcesz zresetować ten serwer?", confirm_resetall: "Czy na pewno chcesz zresetować wszystkie serwery?", context_localserversettings: "Ustawienia serwera lokalnego", modal_colorpicker1: "Kolor ikony", modal_colorpicker2: "Kolor czcionki", modal_colorpicker3: "Kolor etykiety narzędzi", modal_colorpicker4: "Kolor czcionki", modal_guildacronym: "Akronim lokalnego serwera", modal_guildname: "Nazwa serwera lokalnego", modal_header: "Ustawienia serwera lokalnego", modal_ignorecustomname: "Użyj oryginalnej nazwy serwera dla akronimu serwera", modal_invalidurl: "Nieprawidłowy URL", modal_tabheader1: "Serwer", modal_tabheader2: "Kolor etykiety narzędzi", submenu_resetsettings: "Zresetuj serwer", submenu_serversettings: "Zmień ustawienia" }; case "pt-BR": // Portuguese (Brazil) return { confirm_reset: "Tem certeza que deseja redefinir este servidor?", confirm_resetall: "Tem certeza de que deseja redefinir todos os servidores?", context_localserversettings: "Configurações do servidor local", modal_colorpicker1: "Cor do ícone", modal_colorpicker2: "Cor da fonte", modal_colorpicker3: "Cor da dica de ferramenta", modal_colorpicker4: "Cor da fonte", modal_guildacronym: "Acrônimo de servidor local", modal_guildname: "Nome do servidor local", modal_header: "Configurações do servidor local", modal_ignorecustomname: "Use o nome do servidor original para o acrônimo do servidor", modal_invalidurl: "URL inválida", modal_tabheader1: "Servidor", modal_tabheader2: "Cor da dica de ferramenta", submenu_resetsettings: "Reiniciar Servidor", submenu_serversettings: "Mudar configurações" }; case "ro": // Romanian return { confirm_reset: "Sigur doriți să resetați acest server?", confirm_resetall: "Sigur doriți să resetați toate serverele?", context_localserversettings: "Setări locale ale serverului", modal_colorpicker1: "Culoare pictogramă", modal_colorpicker2: "Culoarea fontului", modal_colorpicker3: "Culoare sfat de instrumente", modal_colorpicker4: "Culoarea fontului", modal_guildacronym: "Acronim de server local", modal_guildname: "Numele serverului local", modal_header: "Setări locale ale serverului", modal_ignorecustomname: "Utilizați numele serverului original pentru acronimul serverului", modal_invalidurl: "URL invalid", modal_tabheader1: "Server", modal_tabheader2: "Culoare sfat", submenu_resetsettings: "Resetați serverul", submenu_serversettings: "Schimbă setările" }; case "ru": // Russian return { confirm_reset: "Вы уверены, что хотите сбросить этот сервер?", confirm_resetall: "Вы уверены, что хотите сбросить все серверы?", context_localserversettings: "Настройки локального сервера", modal_colorpicker1: "Цвет значка", modal_colorpicker2: "Цвет шрифта", modal_colorpicker3: "Цвет всплывающей подсказки", modal_colorpicker4: "Цвет шрифта", modal_guildacronym: "Акроним локального сервера", modal_guildname: "Имя локального сервера", modal_header: "Настройки локального сервера", modal_ignorecustomname: "Используйте исходное имя сервера для аббревиатуры сервера", modal_invalidurl: "Неверная ссылка", modal_tabheader1: "Сервер", modal_tabheader2: "Цвет всплывающей подсказки", submenu_resetsettings: "Сбросить сервер", submenu_serversettings: "Изменить настройки" }; case "sv": // Swedish return { confirm_reset: "Är du säker på att du vill återställa den här servern?", confirm_resetall: "Är du säker på att du vill återställa alla servrar?", context_localserversettings: "Lokala serverinställningar", modal_colorpicker1: "Ikonfärg", modal_colorpicker2: "Fontfärg", modal_colorpicker3: "Verktygstipsfärg", modal_colorpicker4: "Fontfärg", modal_guildacronym: "Lokal servernakronym", modal_guildname: "Lokalt servernamn", modal_header: "Lokala serverinställningar", modal_ignorecustomname: "Använd det ursprungliga servernamnet för servernakronym", modal_invalidurl: "Ogiltig URL", modal_tabheader1: "Server", modal_tabheader2: "Verktygstipsfärg", submenu_resetsettings: "Återställ server", submenu_serversettings: "Ändra inställningar" }; case "th": // Thai return { confirm_reset: "แน่ใจไหมว่าต้องการรีเซ็ตเซิร์ฟเวอร์นี้", confirm_resetall: "แน่ใจไหมว่าต้องการรีเซ็ตเซิร์ฟเวอร์ทั้งหมด", context_localserversettings: "การตั้งค่าเซิร์ฟเวอร์ภายใน", modal_colorpicker1: "ไอคอนสี", modal_colorpicker2: "สีตัวอักษร", modal_colorpicker3: "เคล็ดลับเครื่องมือสี", modal_colorpicker4: "สีตัวอักษร", modal_guildacronym: "ตัวย่อเซิร์ฟเวอร์ภายใน", modal_guildname: "ชื่อเซิร์ฟเวอร์ภายใน", modal_header: "การตั้งค่าเซิร์ฟเวอร์ภายใน", modal_ignorecustomname: "ใช้ชื่อเซิร์ฟเวอร์เดิมสำหรับตัวย่อเซิร์ฟเวอร์", modal_invalidurl: "URL ไม่ถูกต้อง", modal_tabheader1: "เซิร์ฟเวอร์", modal_tabheader2: "เคล็ดลับเครื่องมือสี", submenu_resetsettings: "รีเซ็ตเซิร์ฟเวอร์", submenu_serversettings: "เปลี่ยนการตั้งค่า" }; case "tr": // Turkish return { confirm_reset: "Bu Sunucuyu sıfırlamak istediğinizden emin misiniz?", confirm_resetall: "Tüm Sunucuları sıfırlamak istediğinizden emin misiniz?", context_localserversettings: "Yerel Sunucu Ayarları", modal_colorpicker1: "Simge Rengi", modal_colorpicker2: "Yazı rengi", modal_colorpicker3: "Araç İpucu Rengi", modal_colorpicker4: "Yazı rengi", modal_guildacronym: "Yerel Sunucu Kısaltması", modal_guildname: "Yerel Sunucu Adı", modal_header: "Yerel Sunucu Ayarları", modal_ignorecustomname: "Sunucu Kısaltması için orijinal Sunucu Adını kullanın", modal_invalidurl: "Geçersiz URL", modal_tabheader1: "Sunucu", modal_tabheader2: "Araç İpucu Rengi", submenu_resetsettings: "Sunucuyu Sıfırla", submenu_serversettings: "Ayarları değiştir" }; case "uk": // Ukrainian return { confirm_reset: "Справді скинути цей сервер?", confirm_resetall: "Ви впевнені, що хочете скинути всі сервери?", context_localserversettings: "Налаштування локального сервера", modal_colorpicker1: "Значок Колір", modal_colorpicker2: "Колір шрифту", modal_colorpicker3: "Колір підказки", modal_colorpicker4: "Колір шрифту", modal_guildacronym: "Акронім локального сервера", modal_guildname: "Назва локального сервера", modal_header: "Налаштування локального сервера", modal_ignorecustomname: "Використовуйте оригінальне ім’я сервера для абревіатури сервера", modal_invalidurl: "Недійсна URL-адреса", modal_tabheader1: "Сервер", modal_tabheader2: "Колір підказки", submenu_resetsettings: "Скинути сервер", submenu_serversettings: "Змінити налаштування" }; case "vi": // Vietnamese return { confirm_reset: "Bạn có chắc chắn muốn đặt lại Máy chủ này không?", confirm_resetall: "Bạn có chắc chắn muốn đặt lại tất cả Máy chủ không?", context_localserversettings: "Cài đặt máy chủ cục bộ", modal_colorpicker1: "Màu biểu tượng", modal_colorpicker2: "Màu phông chữ", modal_colorpicker3: "Màu chú giải công cụ", modal_colorpicker4: "Màu phông chữ", modal_guildacronym: "Từ viết tắt của máy chủ cục bộ", modal_guildname: "Tên máy chủ cục bộ", modal_header: "Cài đặt máy chủ cục bộ", modal_ignorecustomname: "Sử dụng tên máy chủ ban đầu cho từ viết tắt máy chủ", modal_invalidurl: "URL không hợp lệ", modal_tabheader1: "Người phục vụ", modal_tabheader2: "Màu chú giải công cụ", submenu_resetsettings: "Đặt lại máy chủ", submenu_serversettings: "Thay đổi cài đặt" }; case "zh-CN": // Chinese (China) return { confirm_reset: "您确定要重置此服务器吗?", confirm_resetall: "您确定要重置所有服务器吗?", context_localserversettings: "本地服务器设置", modal_colorpicker1: "图标颜色", modal_colorpicker2: "字体颜色", modal_colorpicker3: "工具提示颜色", modal_colorpicker4: "字体颜色", modal_guildacronym: "本地服务器缩写", modal_guildname: "本地服务器名称", modal_header: "本地服务器设置", modal_ignorecustomname: "使用原始服务器名称作为服务器首字母缩写词", modal_invalidurl: "无效的网址", modal_tabheader1: "服务器", modal_tabheader2: "工具提示颜色", submenu_resetsettings: "重置服务器", submenu_serversettings: "更改设置" }; case "zh-TW": // Chinese (Taiwan) return { confirm_reset: "您確定要重置此服務器嗎?", confirm_resetall: "您確定要重置所有服務器嗎?", context_localserversettings: "本地服務器設置", modal_colorpicker1: "圖標顏色", modal_colorpicker2: "字體顏色", modal_colorpicker3: "工具提示顏色", modal_colorpicker4: "字體顏色", modal_guildacronym: "本地服務器縮​​寫", modal_guildname: "本地服務器名稱", modal_header: "本地服務器設置", modal_ignorecustomname: "使用原始服務器名稱作為服務器首字母縮寫詞", modal_invalidurl: "無效的網址", modal_tabheader1: "服務器", modal_tabheader2: "工具提示顏色", submenu_resetsettings: "重置服務器", submenu_serversettings: "更改設置" }; default: // English return { confirm_reset: "Are you sure you want to reset this Server?", confirm_resetall: "Are you sure you want to reset all Servers?", context_localserversettings: "Local Server Settings", modal_colorpicker1: "Icon Color", modal_colorpicker2: "Font Color", modal_colorpicker3: "Tooltip Color", modal_colorpicker4: "Font Color", modal_guildacronym: "Local Server Acronym", modal_guildname: "Local Server Name", modal_header: "Local Server Settings", modal_ignorecustomname: "Use the original Server Name for the Server Acronym", modal_invalidurl: "Invalid URL", modal_tabheader1: "Server", modal_tabheader2: "Tooltip Color", submenu_resetsettings: "Reset Server", submenu_serversettings: "Change Settings" }; } } }; })(window.BDFDB_Global.PluginUtils.buildPlugin(changeLog)); })();