kill RepoContols
This commit is contained in:
parent
945355220d
commit
6a807073ce
|
@ -129,7 +129,6 @@ https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/Q
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ReadAllNotificationsButton/ReadAllNotificationsButton.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ReadAllNotificationsButton/ReadAllNotificationsButton.plugin.js
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RemoveBlockedMessages/RemoveBlockedMessages.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RemoveBlockedMessages/RemoveBlockedMessages.plugin.js
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RemoveNicknames/RemoveNicknames.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RemoveNicknames/RemoveNicknames.plugin.js
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RepoControls/RepoControls.plugin.js
|
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RevealAllSpoilersOption/RevealAllSpoilersOption.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/RevealAllSpoilersOption/RevealAllSpoilersOption.plugin.js
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ReverseImageSearch/ReverseImageSearch.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ReverseImageSearch/ReverseImageSearch.plugin.js
|
||||||
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/SendLargeMessages/SendLargeMessages.plugin.js
|
https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/SendLargeMessages/SendLargeMessages.plugin.js
|
||||||
|
|
|
@ -6,71 +6,11 @@ var RepoControls = (_ => {
|
||||||
return class RepoControls {
|
return class RepoControls {
|
||||||
getName () {return "RepoControls";}
|
getName () {return "RepoControls";}
|
||||||
|
|
||||||
getVersion () {return "1.3.8";}
|
getVersion () {return "1.3.9";}
|
||||||
|
|
||||||
getAuthor () {return "DevilBro";}
|
getAuthor () {return "DevilBro";}
|
||||||
|
|
||||||
getDescription () {return "Lets you sort and filter your list of downloaded Themes and Plugins.";}
|
getDescription () {return "NO LONGER NEEDED";}
|
||||||
|
|
||||||
constructor () {
|
|
||||||
this.patchedModules = {
|
|
||||||
after: {
|
|
||||||
V2C_ContentColumn: "render",
|
|
||||||
V2C_PluginCard: "render",
|
|
||||||
V2C_ThemeCard: "render",
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
initConstructor () {
|
|
||||||
this.defaults = {
|
|
||||||
settings: {
|
|
||||||
addEditButton: {value:true, description:"Adds an Edit Button to your Plugin and Theme List."},
|
|
||||||
addDeleteButton: {value:true, description:"Adds a Delete Button to your Plugin and Theme List."},
|
|
||||||
confirmDelete: {value:true, description:"Asks for your confirmation before deleting a File."}
|
|
||||||
},
|
|
||||||
sortings: {
|
|
||||||
sort: {
|
|
||||||
value: "name",
|
|
||||||
label: "Sortkey:",
|
|
||||||
values: {
|
|
||||||
name: "Name",
|
|
||||||
author: "Author",
|
|
||||||
version: "Version",
|
|
||||||
description: "Description",
|
|
||||||
enabled: "Enabled",
|
|
||||||
adddate: "Added",
|
|
||||||
moddate: "Modified"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
order: {
|
|
||||||
value: "asc",
|
|
||||||
label: "Order:",
|
|
||||||
values: {
|
|
||||||
asc: "Ascending",
|
|
||||||
desc: "Descending"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
getSettingsPanel () {
|
|
||||||
if (!window.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return;
|
|
||||||
let settings = BDFDB.DataUtils.get(this, "settings");
|
|
||||||
let settingspanel, settingsitems = [];
|
|
||||||
|
|
||||||
for (let key in settings) settingsitems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
|
|
||||||
className: BDFDB.disCN.marginbottom8,
|
|
||||||
type: "Switch",
|
|
||||||
plugin: this,
|
|
||||||
keys: ["settings", key],
|
|
||||||
label: this.defaults.settings[key].description,
|
|
||||||
value: settings[key]
|
|
||||||
}));
|
|
||||||
|
|
||||||
return settingspanel = BDFDB.PluginUtils.createSettingsPanel(this, settingsitems);
|
|
||||||
}
|
|
||||||
|
|
||||||
//legacy
|
//legacy
|
||||||
load () {}
|
load () {}
|
||||||
|
@ -101,7 +41,23 @@ var RepoControls = (_ => {
|
||||||
if (this.started) return;
|
if (this.started) return;
|
||||||
BDFDB.PluginUtils.init(this);
|
BDFDB.PluginUtils.init(this);
|
||||||
|
|
||||||
BDFDB.ModuleUtils.forceAllUpdates(this);
|
BDFDB.ModalUtils.open(this, {
|
||||||
|
header: this.name,
|
||||||
|
subheader: "Delete?",
|
||||||
|
text: `This plugin is no longer needed, because BBD includes the features now natively, click "${BDFDB.LanguageUtils.LanguageStrings.DELETE}" to delete all remaining files created by this plugin.`,
|
||||||
|
buttons: [{
|
||||||
|
color: "RED",
|
||||||
|
contents: BDFDB.LanguageUtils.LanguageStrings.DELETE,
|
||||||
|
close: true,
|
||||||
|
click: _ => {
|
||||||
|
BDFDB.LibraryRequires.fs.unlink(BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), `${this.name}.config.json`), _ => {});
|
||||||
|
BDFDB.LibraryRequires.fs.unlink(BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), `${this.name}.plugin.js`), _ => {});
|
||||||
|
}
|
||||||
|
}],
|
||||||
|
onClose: _ => {
|
||||||
|
BDFDB.BDUtils.disablePlugin(this.name);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
else console.error(`%c[${this.getName()}]%c`, "color: #3a71c1; font-weight: 700;", "", "Fatal Error: Could not load BD functions!");
|
else console.error(`%c[${this.getName()}]%c`, "color: #3a71c1; font-weight: 700;", "", "Fatal Error: Could not load BD functions!");
|
||||||
}
|
}
|
||||||
|
@ -111,214 +67,8 @@ var RepoControls = (_ => {
|
||||||
if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
|
||||||
this.stopping = true;
|
this.stopping = true;
|
||||||
|
|
||||||
BDFDB.ModuleUtils.forceAllUpdates(this);
|
|
||||||
|
|
||||||
BDFDB.PluginUtils.clear(this);
|
BDFDB.PluginUtils.clear(this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// begin of own functions
|
|
||||||
|
|
||||||
processV2CContentColumn (e) {
|
|
||||||
let [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {key: ["plugin-list", "theme-list"]});
|
|
||||||
if (index > -1) {
|
|
||||||
let list = children[index];
|
|
||||||
this.injectControls(e.instance, list, children, index, children[index].key.split("-")[0]);
|
|
||||||
this.sortEntries(null, list);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
processV2CPluginCard (e) {
|
|
||||||
this.processV2CThemeCard(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
processV2CThemeCard (e) {
|
|
||||||
if (!e.instance.props.RCdata) return;
|
|
||||||
let [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", BDFDB.disCN._repocontrols]]});
|
|
||||||
if (index > -1) {
|
|
||||||
let settings = BDFDB.DataUtils.get(this, "settings");
|
|
||||||
if (settings.addDeleteButton) children[index].props.children.unshift(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, {
|
|
||||||
text: BDFDB.LanguageUtils.LanguageStrings.DELETE,
|
|
||||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Clickable, {
|
|
||||||
className: BDFDB.disCN._repoentryiconwrapper,
|
|
||||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
|
|
||||||
className: BDFDB.disCN.svgicon,
|
|
||||||
name: BDFDB.LibraryComponents.SvgIcon.Names.NOVA_TRASH
|
|
||||||
}),
|
|
||||||
onClick: _ => {
|
|
||||||
let deleteFile = _ => {
|
|
||||||
BDFDB.LibraryRequires.fs.unlink(e.instance.props.RCdata.path, (error) => {
|
|
||||||
if (error) BDFDB.NotificationUtils.toast(`Unable to delete ${e.instance.props.RCdata.type} "${e.returnvalue.props["data-name"]}".`, {type:"danger"});
|
|
||||||
else BDFDB.NotificationUtils.toast(`Successfully deleted ${e.instance.props.RCdata.type} "${e.returnvalue.props["data-name"]}".`, {type:"success"});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
if (!settings.confirmDelete) deleteFile();
|
|
||||||
else BDFDB.ModalUtils.confirm(this, `Are you sure you want to delete the ${e.instance.props.RCdata.type} "${e.returnvalue.props["data-name"]}"?`, deleteFile);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}));
|
|
||||||
if (settings.addEditButton) children[index].props.children.unshift(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TooltipContainer, {
|
|
||||||
text: BDFDB.LanguageUtils.LanguageStrings.EDIT,
|
|
||||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Clickable, {
|
|
||||||
className: BDFDB.disCN._repoentryiconwrapper,
|
|
||||||
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
|
|
||||||
className: BDFDB.disCN.svgicon,
|
|
||||||
name: BDFDB.LibraryComponents.SvgIcon.Names.PENCIL
|
|
||||||
}),
|
|
||||||
onClick: _ => {
|
|
||||||
if (!BDFDB.LibraryRequires.electron.shell.openItem(e.instance.props.RCdata.path)) BDFDB.NotificationUtils.toast(`Unable to open the ${e.instance.props.RCdata.type} "${e.returnvalue.props["data-name"]}".`, {type:"danger"});
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}));
|
|
||||||
this.highlightsearchKey(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
injectControls (instance, parent, children, index, type) {
|
|
||||||
let sortings = BDFDB.DataUtils.get(this, "sortings");
|
|
||||||
children.splice(index, 0, BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
|
|
||||||
className: BDFDB.disCN.marginbottom8,
|
|
||||||
justify: BDFDB.LibraryComponents.Flex.Justify.BETWEEN,
|
|
||||||
align: BDFDB.LibraryComponents.Flex.Align.CENTER,
|
|
||||||
children: [
|
|
||||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SearchBar, {
|
|
||||||
onChange: value => {
|
|
||||||
BDFDB.TimeUtils.clear(searchTimeout);
|
|
||||||
searchTimeout = BDFDB.TimeUtils.timeout(_ => {
|
|
||||||
this.sortEntries(instance, parent, value);
|
|
||||||
}, 1000);
|
|
||||||
},
|
|
||||||
onClear: _ => {
|
|
||||||
this.sortEntries(instance, parent, "");
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Button, {
|
|
||||||
color: BDFDB.LibraryComponents.Button.Colors.GREEN,
|
|
||||||
size: BDFDB.LibraryComponents.Button.Sizes.MIN,
|
|
||||||
onClick: _ => {
|
|
||||||
this.toggleAll(type, instance, true);
|
|
||||||
},
|
|
||||||
children: "Enable All"
|
|
||||||
}),
|
|
||||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Button, {
|
|
||||||
color: BDFDB.LibraryComponents.Button.Colors.RED,
|
|
||||||
size: BDFDB.LibraryComponents.Button.Sizes.MIN,
|
|
||||||
onClick: _ => {
|
|
||||||
this.toggleAll(type, instance, false);
|
|
||||||
},
|
|
||||||
children: "Disable All"
|
|
||||||
}),
|
|
||||||
].concat(Object.keys(sortings).map(key =>
|
|
||||||
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.QuickSelect, {
|
|
||||||
nativeComponent: true,
|
|
||||||
label: this.defaults.sortings[key].label,
|
|
||||||
value: {
|
|
||||||
label: this.defaults.sortings[key].values[sortings[key]],
|
|
||||||
value: sortings[key]
|
|
||||||
},
|
|
||||||
options: Object.keys(this.defaults.sortings[key].values).map(valuekey => {return {
|
|
||||||
label: this.defaults.sortings[key].values[valuekey],
|
|
||||||
value: valuekey
|
|
||||||
}}),
|
|
||||||
onChange: value => {
|
|
||||||
BDFDB.DataUtils.save(value, this, "sortings", key);
|
|
||||||
this.sortEntries(instance, parent);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
))
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
sortEntries (instance, parent, searchKey = parent.props.searchKey) {
|
|
||||||
if (instance) instance = BDFDB.ReactUtils.findOwner(instance, {key: ["plugin-list", "theme-list"]});
|
|
||||||
|
|
||||||
let sortings = BDFDB.DataUtils.get(this, "sortings");
|
|
||||||
|
|
||||||
parent.props.searchKey = (searchKey || "").toUpperCase();
|
|
||||||
|
|
||||||
if (!parent.props.entries) parent.props.entries = parent.props.children;
|
|
||||||
|
|
||||||
let entries = [].concat(parent.props.entries);
|
|
||||||
|
|
||||||
for (let i in entries) {
|
|
||||||
let entry = BDFDB.ReactUtils.findChild(entries[i], {props: ["plugin", "theme"], someProps: true});
|
|
||||||
if (entry) {
|
|
||||||
if (!entry.props.RCdata) {
|
|
||||||
entry.props.RCdata = {};
|
|
||||||
if (entry.props.plugin) {
|
|
||||||
["name", "author", "version", "description"].forEach(key => {
|
|
||||||
let funcName = "get" + BDFDB.LibraryModules.StringUtils.upperCaseFirstChar(key);
|
|
||||||
let value = typeof entry.props.plugin[funcName] == "function" ? entry.props.plugin[funcName]() : "";
|
|
||||||
entry.props.RCdata[key] = value && value.toUpperCase().trim() || "";
|
|
||||||
});
|
|
||||||
entry.props.RCdata.type = "plugin";
|
|
||||||
entry.props.RCdata.enabled = BDFDB.BDUtils.isPluginEnabled(entry.key) ? 1 : 2;
|
|
||||||
let loadedPlugin = BDFDB.BDUtils.getPlugin(entry.key, false, true);
|
|
||||||
entry.props.RCdata.path = loadedPlugin && typeof loadedPlugin.filename == "string" && BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getPluginsFolder(), loadedPlugin.filename);
|
|
||||||
}
|
|
||||||
else if (entry.props.theme) {
|
|
||||||
["name", "author", "version", "description"].forEach(key => {
|
|
||||||
entry.props.RCdata[key] = entry.props.theme[key] && entry.props.theme[key].toUpperCase().trim() || "";
|
|
||||||
});
|
|
||||||
entry.props.RCdata.type = "theme";
|
|
||||||
entry.props.RCdata.enabled = BDFDB.BDUtils.isThemeEnabled(entry.key) ? 1 : 2;
|
|
||||||
let loadedTheme = BDFDB.BDUtils.getTheme(entry.key, false);
|
|
||||||
entry.props.RCdata.path = loadedTheme && typeof loadedTheme.filename == "string" && BDFDB.LibraryRequires.path.join(BDFDB.BDUtils.getThemesFolder(), loadedTheme.filename);
|
|
||||||
}
|
|
||||||
let stats = entry.props.RCdata.path && BDFDB.LibraryRequires.fs.statSync(entry.props.RCdata.path);
|
|
||||||
entry.props.RCdata.adddate = stats && stats.atime.getTime();
|
|
||||||
entry.props.RCdata.moddate = stats && stats.mtime.getTime();
|
|
||||||
entry.props.RCdata.search = [entry.props.RCdata.name, entry.props.RCdata.author, entry.props.RCdata.description].filter(n => n).join(" ");
|
|
||||||
}
|
|
||||||
entry.props.RCdata.searchKey = parent.props.searchKey;
|
|
||||||
if (parent.props.searchKey && entry.props.RCdata.search.indexOf(parent.props.searchKey) == -1) entries[i] = null;
|
|
||||||
else entries[i].props.RCdata = entry.props.RCdata;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let order = sortings.order == "asc" ? -1 : 1;
|
|
||||||
parent.props.children = entries.filter(n => n).sort(function (x, y) {
|
|
||||||
return x.props.RCdata[sortings.sort] < y.props.RCdata[sortings.sort] ? order : x.props.RCdata[sortings.sort] > y.props.RCdata[sortings.sort] ? order * -1 : 0;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (instance) {
|
|
||||||
BDFDB.ReactUtils.forceUpdate(instance);
|
|
||||||
BDFDB.TimeUtils.timeout(_ => {
|
|
||||||
BDFDB.ReactUtils.forceUpdate(BDFDB.ReactUtils.findOwner(instance, {props: instance._reactInternalFiber.key.split("-")[0], all:true}));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
highlightsearchKey (e) {
|
|
||||||
if (!e.instance.props.RCdata.searchKey) return;
|
|
||||||
[BDFDB.disCN._reponame, BDFDB.disCN._repoauthor, BDFDB.disCN._repodescription].forEach(className => {
|
|
||||||
let [children, index] = BDFDB.ReactUtils.findChildren(e.returnvalue, {props: [["className", className]]});
|
|
||||||
if (index > -1) {
|
|
||||||
let originalText = BDFDB.StringUtils.htmlEscape(children[index].props.children);
|
|
||||||
let highlightedText = BDFDB.StringUtils.highlight(originalText, e.instance.props.RCdata.searchKey);
|
|
||||||
if (highlightedText != originalText) children[index].props.children = BDFDB.ReactUtils.elementToReact(BDFDB.DOMUtils.create(highlightedText));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
toggleAll (type, instance, enable) {
|
|
||||||
let listnode = BDFDB.ReactUtils.findDOMNode(BDFDB.ReactUtils.findOwner(instance, {key: ["plugin-list", "theme-list"]}));
|
|
||||||
if (listnode) BDFDB.ModalUtils.confirm(this, `Are you sure you want to ${enable ? "enable" : "disable"} all ${type[0].toUpperCase() + type.slice(1)}s?`, _ => {
|
|
||||||
for (let header of listnode.querySelectorAll(BDFDB.dotCN._repoheader)) {
|
|
||||||
if (header.querySelector(BDFDB.dotCN._reponame).textContent.toLowerCase().indexOf(this.name.toLowerCase()) != 0) {
|
|
||||||
let switchwrap = header.querySelector(BDFDB.dotCN._repocheckboxwrap);
|
|
||||||
if (switchwrap) {
|
|
||||||
let switchinner = switchwrap.querySelector(BDFDB.dotCN._repocheckboxinner);
|
|
||||||
let switchinput = switchwrap.querySelector(BDFDB.dotCN._repocheckbox);
|
|
||||||
if (switchinner && switchinput) {
|
|
||||||
if (BDFDB.DOMUtils.containsClass(switchinner, BDFDB.disCN._repocheckboxchecked) && !enable) switchinput.click();
|
|
||||||
else if (!BDFDB.DOMUtils.containsClass(switchinner, BDFDB.disCN._repocheckboxchecked) && enable) switchinput.click();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})();
|
})();
|
Loading…
Reference in New Issue