diff --git a/Library/_res/0BDFDB.data.json b/Library/_res/0BDFDB.data.json
index d6ecb89543..9251a1e9c4 100644
--- a/Library/_res/0BDFDB.data.json
+++ b/Library/_res/0BDFDB.data.json
@@ -4,7 +4,8 @@
"BDFDB": "https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js",
"CreationDate": "https://mwittrien.github.io/BetterDiscordAddons/_DEAD/CreationDate.plugin.js",
"JoinedAtDate": "https://mwittrien.github.io/BetterDiscordAddons/_DEAD/JoinedAtDate.plugin.js",
- "ShowHiddenChannels": "https://mwittrien.github.io/BetterDiscordAddons/_DEAD/ShowHiddenChannels.plugin.js"
+ "ShowHiddenChannels": "https://mwittrien.github.io/BetterDiscordAddons/_DEAD/ShowHiddenChannels.plugin.js",
+ "ThemeSettings": "https://mwittrien.github.io/BetterDiscordAddons/_DEAD/ThemeSettings.plugin.js"
},
"LibraryRequires": ["electron", "fs", "path", "process", "request"],
"DiscordObjects": {
diff --git a/Plugins/README.md b/Plugins/README.md
index 4490aac66e..d70340a7db 100644
--- a/Plugins/README.md
+++ b/Plugins/README.md
@@ -55,7 +55,6 @@
- [Spotify Controls](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/SpotifyControls) - Adds a Control Panel while listening to Spotify on a connected Account
- [Staff Tag](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/StaffTag) - Adds a Crown/Tag to Server Owners (or Admins/Management)
- [Theme Repo](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ThemeRepo) - Allows you to download all Themes from BD's Website within Discord
- - [Theme Settings](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ThemeSettings) - Allows you to change Theme Variables within Discord
- [Timed Light Dark Mode](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/TimedLightDarkMode) - Adds a Time Slider to the Appearance Settings
- [Top Role Everywhere](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/TopRoleEverywhere) - Adds the highest Role of a User as a Tag
- [Translator](https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/Translator) - Allows you to translate Messages and your outgoing Messages within Discord
diff --git a/Plugins/ThemeSettings/README.md b/Plugins/ThemeSettings/README.md
deleted file mode 100644
index cb3c981a76..0000000000
--- a/Plugins/ThemeSettings/README.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# Theme Settings [![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=ThemeSettings
-
-[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
-
-Allows you to change Theme Variables within Discord
-
-
-![cover](https://mwittrien.github.io/BetterDiscordAddons/Plugins/ThemeSettings/_res/cover.png)
-
-![screenshot1](https://mwittrien.github.io/BetterDiscordAddons/Plugins/ThemeSettings/_res/screenshot1.png)
\ No newline at end of file
diff --git a/Plugins/ThemeSettings/ThemeSettings.plugin.js b/Plugins/ThemeSettings/ThemeSettings.plugin.js
deleted file mode 100644
index 936fcfa6ba..0000000000
--- a/Plugins/ThemeSettings/ThemeSettings.plugin.js
+++ /dev/null
@@ -1,269 +0,0 @@
-/**
- * @name ThemeSettings
- * @author DevilBro
- * @authorId 278543574059057154
- * @version 1.3.5
- * @description Allows you to change Theme Variables within Discord
- * @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/ThemeSettings/
- * @updateUrl https://mwittrien.github.io/BetterDiscordAddons/Plugins/ThemeSettings/ThemeSettings.plugin.js
- */
-
-module.exports = (_ => {
- const changeLog = {
- improved: {
- "Changed Location": "Due to the new Plugin Guidelines, which forbid changes to BDs Plugin/Themes Pages, the option to change the variables for Themes are now inside the Plugin Settings of 'ThemeSettings'"
- }
- };
-
- 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 dir;
-
- return class ThemeSettings extends Plugin {
- onLoad () {
- dir = BDFDB.BDUtils.getThemesFolder();
-
- this.css = `
- ${BDFDB.dotCN._themesettingsgrid} {
- display: grid;
- grid-template-columns: 50% auto;
- }
- ${BDFDB.dotCN._themesettingscard} {
- display: flex;
- align-items: center;
- padding: 10px;
- }
- ${BDFDB.dotCN._themesettingscardname} {
- flex: 1 1 auto;
- margin-right: 10px;
- }
- `;
- }
-
- onStart () {}
-
- onStop () {}
-
- getSettingsPanel () {
- let themes = window.BdApi && BdApi.Themes && BdApi.Themes.getAll && BdApi.Themes.getAll().map(theme => {
- let css = theme.css.replace(/\r/g, "");
- let imports = css.split("\n@import url(").splice(1).map(n => [n.split(");")[0], true]).concat(css.split("\n/* @import url(").splice(1).map(n => [n.split("); */")[0], false]));
- let vars = css.split(":root");
- if (vars.length > 1) {
- vars = vars[1].replace(/\t\(/g, " (").replace(/\t| {2,}/g, "").replace(/\/\*\n*((?!\/\*|\*\/).|\n)*\n+((?!\/\*|\*\/).|\n)*\n*\*\//g, "").replace(/\n\/\*.*?\*\//g, "").replace(/\n/g, "");
- vars = vars.split("{");
- vars.shift();
- vars = vars.join("{").replace(/\s*(:|;|--|\*)\s*/g, "$1");
- vars = vars.split("}")[0];
- vars = (vars.endsWith(";") ? vars.slice(0, -1) : vars).slice(2).split(/;--|\*\/--/);
- }
- else vars = [];
-
- if (imports.length || vars.length) return {data: theme, imports, vars};
- }).filter(n => n);
- return themes && themes.length && BDFDB.ReactUtils.createElement("div", {
- className: BDFDB.disCN._themesettingsgrid,
- children: themes.map(theme => BDFDB.ReactUtils.createElement("div", {
- className: BDFDB.disCN._themesettingscard,
- children: [
- BDFDB.ReactUtils.createElement("div", {
- className: BDFDB.disCN._themesettingscardname,
- children: theme.data.name
- }),
- BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Button, {
- size: BDFDB.LibraryComponents.Button.Sizes.SMALL,
- children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
- align: BDFDB.LibraryComponents.Flex.Align.CENTER,
- children: [
- BDFDB.ReactUtils.createElement("div", {
- children: "Edit"
- }),
- BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
- className: BDFDB.disCN.marginleft4,
- name: BDFDB.LibraryComponents.SvgIcon.Names.PENCIL
- })
- ]
- }),
- onClick: _ => {
- let importInstances = {}, inputInstances = {};
- BDFDB.ModalUtils.open(this, {
- header: `${theme.data.name} ${BDFDB.LanguageUtils.LanguageStrings.SETTINGS}`,
- subHeader: "",
- size: "MEDIUM",
- children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanel, {
- addon: theme.data,
- children: _ => {
- let settingsItems = [];
-
- let varInputs = [];
- for (let i in theme.vars) {
- let varStr = theme.vars[i].split(":");
- let varName = varStr.shift().trim();
- varStr = varStr.join(":").split(/;[^A-z0-9]|\/\*/);
- let varValue = varStr.shift().trim();
- if (varValue) {
- let childType = "text", childMode = "";
- let isColor = BDFDB.ColorUtils.getType(varValue);
- let isComp = !isColor && /^[0-9 ]+,[0-9 ]+,[0-9 ]+$/g.test(varValue);
- if (isColor || isComp) {
- childType = "color";
- childMode = isComp && "comp";
- }
- else {
- let isUrlFile = /url\(.+\)/gi.test(varValue);
- let isFile = !isUrlFile && /(http(s)?):\/\/[(www\.)?a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,6}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)/.test(varValue);
- if (isFile || isUrlFile) {
- childType = "file";
- childMode = isUrlFile && "url";
- }
- }
- let varDescription = varStr.join("").replace(/\*\/|\/\*/g, "").replace(/:/g, ": ").replace(/: \//g, ":/").replace(/--/g, " --").replace(/\( --/g, "(--").trim();
- varInputs.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
- type: "TextInput",
- margin: 8,
- childProps: {
- type: childType,
- mode: childMode,
- filter: childType == "file" && "image",
- ref: instance => {if (instance) inputInstances[i] = instance;}
- },
- label: varName.split("-").map(BDFDB.StringUtils.upperCaseFirstChar).join(" "),
- note: varDescription && varDescription.indexOf("*") == 0 ? varDescription.slice(1) : varDescription,
- basis: "70%",
- name: varName,
- value: varValue,
- oldValue: varValue,
- defaultValue: varValue,
- placeholder: varValue
- }));
- }
- };
-
- if (theme.imports.length) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelList, {
- title: "Imports:",
- dividerBottom: varInputs.length,
- children: theme.imports.map((impo, i) => {
- let name = impo[0].split("/").pop().replace(/"/g, "");
- return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
- type: "Switch",
- margin: 8,
- childProps: {ref: instance => {if (instance) importInstances[i] = instance;}},
- label: name[0].toUpperCase() + name.slice(1),
- note: impo[0].replace(/"/g, ""),
- name: impo[0],
- value: impo[1],
- oldValue: impo[1].toString(),
- defaultValue: impo[1].toString()
- });
- })
- }));
- if (varInputs.length) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelList, {
- title: "Variables:",
- children: varInputs
- }));
-
- return settingsItems;
- }
- }),
- buttons: [{
- contents: BDFDB.LanguageUtils.LanguageStrings.SAVE,
- color: "BRAND",
- onClick: _ => this.updateTheme(theme.data, {imports: importInstances, inputs: inputInstances}, false)
- }, {
- contents: BDFDB.LanguageUtils.LanguageStrings.RESET,
- look: "LINK",
- onClick: _ => this.updateTheme(theme.data, {imports: importInstances, inputs: inputInstances}, true)
- }]
- });
- }
- })
- ]
- }))
- });
- }
-
- updateTheme (theme, instances, reset) {
- let path = BDFDB.LibraryRequires.path.join(dir, theme.filename);
- let css = BDFDB.LibraryRequires.fs.readFileSync(path).toString();
- if (css) {
- let amount = 0;
- for (let i in instances.imports) {
- let input = instances.imports[i];
- let oldValue = input.props.oldValue;
- let newValue = reset ? input.props.defaultValue : input.props.value;
- if (newValue.toString() != oldValue.toString()) {
- let trueValue = typeof newValue == "string" ? newValue == "true" : newValue;
- let importUrl = input.props.name;
- if (trueValue) css = css.replace(new RegExp(`\\n${BDFDB.StringUtils.regEscape("/* @import url(" + importUrl + "); */")}`, "g"), `\n@import url(${importUrl});`);
- else css = css.replace(new RegExp(`\\n${BDFDB.StringUtils.regEscape("@import url(" + importUrl + ");")}`, "g"), `\n/* @import url(${importUrl}); */`);
- input.props.value = trueValue;
- input.props.oldValue = newValue;
- amount++;
- }
- }
- for (let i in instances.inputs) {
- let input = instances.inputs[i];
- let oldValue = input.props.oldValue;
- let newValue = reset ? input.props.defaultValue : input.props.value;
- if (newValue && newValue.trim() && newValue != oldValue) {
- let varName = input.props.name;
- css = css.replace(new RegExp(`--${BDFDB.StringUtils.regEscape(varName)}(\\s*):(\\s*)${BDFDB.StringUtils.regEscape(oldValue)}`,"g"), `--${varName}$1: $2${newValue}`);
- input.props.value = newValue;
- input.props.oldValue = newValue;
- input.props.placeholder = newValue;
- amount++;
- }
- }
- if (amount > 0) {
- BDFDB.ReactUtils.forceUpdate(BDFDB.ObjectUtils.toArray(instances.imports), BDFDB.ObjectUtils.toArray(instances.inputs));
- BDFDB.LibraryRequires.fs.writeFileSync(path, css);
- BDFDB.NotificationUtils.toast(`Updated ${amount} Variable${amount == 1 ? "" : "s"} in '${theme.filename}'`, {type: "success"});
- }
- else BDFDB.NotificationUtils.toast(`There are no changed Variables to be updated in '${theme.filename}'`, {type: "warning"});
- }
- else BDFDB.NotificationUtils.toast(`Could not find Theme File '${theme.filename}'`, {type: "danger"});
- }
- };
- })(window.BDFDB_Global.PluginUtils.buildPlugin(changeLog));
-})();
\ No newline at end of file
diff --git a/Plugins/ThemeSettings/_res/cover.png b/Plugins/ThemeSettings/_res/cover.png
deleted file mode 100644
index cd508b55b1..0000000000
Binary files a/Plugins/ThemeSettings/_res/cover.png and /dev/null differ
diff --git a/Plugins/ThemeSettings/_res/screenshot1.png b/Plugins/ThemeSettings/_res/screenshot1.png
deleted file mode 100644
index f7845f9e2b..0000000000
Binary files a/Plugins/ThemeSettings/_res/screenshot1.png and /dev/null differ
diff --git a/_DEAD/ThemeSettings.plugin.js b/_DEAD/ThemeSettings.plugin.js
new file mode 100644
index 0000000000..923c739631
--- /dev/null
+++ b/_DEAD/ThemeSettings.plugin.js
@@ -0,0 +1,74 @@
+/**
+ * @name ThemeSettings
+ * @author DevilBro
+ * @authorId 278543574059057154
+ * @version 9.9.9
+ * @description PLUGIN WAS DISCONTINUED
+ */
+
+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]) => {
+ return class ThemeSettings extends Plugin {
+ onLoad () {}
+
+ onStart () {
+ BDFDB.ModalUtils.open(this, {
+ header: "PLUGIN WAS DISCONTINUED",
+ children: [
+ BDFDB.ReactUtils.createElement("span", {children: "BETTERDISCORD DEVS ARE WORKING ON A NATIVE IMPLEMENTATION OF SETTINGS FOR THEMES, THAT'S WHY I DECIDED TO ALREADY DROP THEMESETTINGS, HAVING TO FIX ONE LESS PLUGIN"}),
+ BDFDB.ReactUtils.createElement("strong", {children: "DELETE"}),
+ BDFDB.ReactUtils.createElement("span", {children: " TO REMOVE THIS EMPTY PLUGIN FILE."})
+ ],
+ buttons: [
+ {contents: "DELETE", close: true, color: "RED", onClick: _ => {
+ BDFDB.LibraryRequires.fs.unlink(BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), "ThemeSettings.plugin.js"), error => {});
+ BDFDB.LibraryRequires.fs.unlink(BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), "ThemeSettings.config.json"), error => {});
+ }}
+ ]
+ });
+ }
+
+ onStop () {}
+ };
+ })(window.BDFDB_Global.PluginUtils.buildPlugin(changeLog));
+})();