diff --git a/Plugins/README.md b/Plugins/README.md index f5ae64f795..8786057470 100644 --- a/Plugins/README.md +++ b/Plugins/README.md @@ -52,6 +52,7 @@ - [Server Details](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ServerDetails) - Shows Server Details in the Server List Tooltip - [Server Folders](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ServerFolders) - Changes Discord's Folders, Servers open in a new Container, also adds extra Features to more easily organize, customize and manage your Folders - [Server Hider](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ServerHider) - Allows you to hide certain Servers in your Server List + - [Show Connections](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ShowConnections) - Shows the connected Accounts of a User in the UserPopout - [Show Hidden Channels](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ShowHiddenChannels) - Displays all hidden Channels, which can't be accessed due to Role Restrictions, this won't allow you to read them (impossible) - [Spell Check](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/SpellCheck) - Adds a Spell Check to all Message Inputs - [Spotify Controls](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/SpotifyControls) - Adds a Control Panel while listening to Spotify on a connected Account diff --git a/Plugins/ShowConnections/README.md b/Plugins/ShowConnections/README.md new file mode 100644 index 0000000000..97d83c0210 --- /dev/null +++ b/Plugins/ShowConnections/README.md @@ -0,0 +1,17 @@ +# Show Connections [![Download][download-badge]][download-link] [![Support][support-badge]][support-link] [![PayPal][paypal-badge]][paypal-link] [![Patreon][patreon-badge]][patreon-link] + +[download-badge]: https://img.shields.io/badge/Download-%233a71c1.svg?style=flat&logo= +[download-link]: https://mwittrien.github.io/downloader/?plugin=ShowConnections + +[support-badge]: https://img.shields.io/badge/Support-%2343b581.svg?style=flat&logo= +[support-link]: https://discord.com/invite/Jx3TjNS + +[paypal-badge]: https://img.shields.io/badge/PayPal-%23003087.svg?style=flat&logo= +[paypal-link]: https://paypal.me/MircoWittrien + +[patreon-badge]: https://img.shields.io/badge/Patreon-%23F96854.svg?style=flat&logo= +[patreon-link]: https://patreon.com/MircoWittrien + +Shows the connected Accounts of a User in the UserPopout + +![screenshot1](https://mwittrien.github.io/BetterDiscordAddons/Plugins/ShowConnections/_res/screenshot1.png) \ No newline at end of file diff --git a/Plugins/ShowConnections/ShowConnections.plugin.js b/Plugins/ShowConnections/ShowConnections.plugin.js new file mode 100644 index 0000000000..bd137f1fb3 --- /dev/null +++ b/Plugins/ShowConnections/ShowConnections.plugin.js @@ -0,0 +1,179 @@ +/** + * @name ShowConnections + * @author DevilBro + * @authorId 278543574059057154 + * @version 1.0.0 + * @description Shows the connected Accounts of a User in the UserPopout + * @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/ShowConnections/ + * @updateUrl https://mwittrien.github.io/BetterDiscordAddons/Plugins/ShowConnections/ShowConnections.plugin.js + */ + +module.exports = (_ => { + const config = { + "info": { + "name": "ShowConnections", + "author": "DevilBro", + "version": "1.0.0", + "description": "Shows the connected Accounts of a User in the UserPopout" + } + }; + + return !window.BDFDB_Global || (!window.BDFDB_Global.loaded && !window.BDFDB_Global.started) ? class { + getName () {return config.info.name;} + getAuthor () {return config.info.author;} + getVersion () {return config.info.version;} + getDescription () {return `The Library Plugin needed for ${config.info.name} is missing. Open the Plugin Settings to download it. \n\n${config.info.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 ${config.info.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(config.info.name)) window.BDFDB_Global.pluginQueue.push(config.info.name); + } + start () {this.load();} + stop () {} + getSettingsPanel () { + let template = document.createElement("template"); + template.innerHTML = `
The Library Plugin needed for ${config.info.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 loadedUsers = {}, fetchTimeout, currentPopup = {}; + + return class ShowConnections extends Plugin { + onLoad () { + this.patchedModules = { + after: { + UserPopout: ["render", "componentDidMount"] + } + }; + + this.css = ` + ${BDFDB.dotCN._showconnectionsconnections} { + display: flex; + flex-wrap: wrap; + margin-bottom: 6px; + } + ${BDFDB.dotCN._showconnectionsconnection} { + position: relative; + width: 28px; + height: 28px; + margin: 0 10px 10px 0; + } + ${BDFDB.dotCN._showconnectionsicon} { + margin: -15% 0 0 -15%; + width: 130%; + height: 130%; + } + ${BDFDB.dotCN._showconnectionsverifiedbadge} { + position: absolute; + bottom: -3px; + right: -3px; + } + `; + } + + onStart () { + BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.DispatchApiUtils, "dispatch", {after: e => { + if (BDFDB.ObjectUtils.is(e.methodArguments[0]) && e.methodArguments[0].type == BDFDB.DiscordConstants.ActionTypes.USER_PROFILE_FETCH_SUCCESS && e.methodArguments[0].user && e.methodArguments[0].connected_accounts) { + loadedUsers[e.methodArguments[0].user.id] = e.methodArguments[0].connected_accounts; + if (currentPopup.id == e.methodArguments[0].user.id) { + BDFDB.ReactUtils.forceUpdate(currentPopup.instance); + currentPopup = {}; + } + } + }}); + + BDFDB.PatchUtils.forceAllUpdates(this); + } + + onStop () { + BDFDB.PatchUtils.forceAllUpdates(this); + } + + processUserPopout (e) { + if (e.instance.props.user && !e.instance.props.user.bot && e.instance.props.user.discriminator != "0000") { + if (e.node) currentPopup = {id: e.instance.props.user.id, instance: e.instance}; + else { + if (loadedUsers[e.instance.props.user.id]) { + if (loadedUsers[e.instance.props.user.id].length) { + let isLightTheme = BDFDB.DiscordUtils.getTheme() == BDFDB.disCN.themelight; + let bodyInner = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.userpopoutbodyinnerwrapper]]}); + if (bodyInner) bodyInner.props.children.splice(1, 0, [ + BDFDB.ReactUtils.createElement("div", { + className: BDFDB.disCN.userpopoutbodytitle, + children: BDFDB.LanguageUtils.LanguageStrings.CONNECTIONS + }), + BDFDB.ReactUtils.createElement("div", { + className: BDFDB.disCN._showconnectionsconnections, + children: loadedUsers[e.instance.props.user.id].filter(c => BDFDB.LibraryModules.ConnectionProviderUtils.isSupported(c.type)).map(c => { + let provider = BDFDB.LibraryModules.ConnectionProviderUtils.get(c.type); + let url = provider.getPlatformUserUrl && provider.getPlatformUserUrl(c); + return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, { + text: `${provider.name}: ${c.name}`, + tooltipConfig: {backgroundColor: provider.color, color: !provider.color && "grey"}, + children: BDFDB.ReactUtils.createElement(!url ? "div" : BDFDB.LibraryComponents.Anchor, { + className: BDFDB.DOMUtils.formatClassName(BDFDB.disCN._showconnectionsconnection, url && BDFDB.disCN.cursorpointer), + href: url, + children: [ + BDFDB.ReactUtils.createElement("img", { + className: BDFDB.disCN._showconnectionsicon, + alt: BDFDB.LanguageUtils.LanguageStringsFormat("IMG_ALT_LOGO", provider.name), + src: provider.icon.color + }), + c.verified && BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, { + text: BDFDB.LanguageUtils.LanguageStrings.CONNECTION_VERIFIED, + tooltipConfig: {color: "brand"}, + children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FlowerStar, { + className: BDFDB.disCN._showconnectionsverifiedbadge, + color: isLightTheme ? BDFDB.DiscordConstants.Colors.STATUS_GREY_200 : BDFDB.DiscordConstants.Colors.PRIMARY_DARK, + children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, { + name: BDFDB.LibraryComponents.SvgIcon.Names.CHECKMARK, + width: 12, + height: 12, + color: isLightTheme ? BDFDB.DiscordConstants.Colors.STATUS_GREY_500 : BDFDB.DiscordConstants.Colors.WHITE + }) + }) + }) + ] + }) + }); + }) + }) + ]); + } + } + else { + BDFDB.TimeUtils.clear(fetchTimeout); + fetchTimeout = BDFDB.TimeUtils.timeout(_ => { + if (!loadedUsers[e.instance.props.user.id]) BDFDB.LibraryModules.UserProfileUtils.fetchProfile(e.instance.props.user.id); + }, 1000); + } + } + } + } + }; + })(window.BDFDB_Global.PluginUtils.buildPlugin(config)); +})(); \ No newline at end of file diff --git a/Plugins/ShowConnections/_res/cover.png b/Plugins/ShowConnections/_res/cover.png new file mode 100644 index 0000000000..fd75c56886 Binary files /dev/null and b/Plugins/ShowConnections/_res/cover.png differ diff --git a/Plugins/ShowConnections/_res/screenshot1.png b/Plugins/ShowConnections/_res/screenshot1.png new file mode 100644 index 0000000000..c0575e3eb3 Binary files /dev/null and b/Plugins/ShowConnections/_res/screenshot1.png differ