BetterDiscordAddons/Plugins/ChatAliases/ChatAliases.plugin.js

573 lines
25 KiB
JavaScript
Raw Normal View History

2020-02-27 08:44:03 +01:00
//META{"name":"ChatAliases","authorId":"278543574059057154","invite":"Jx3TjNS","donate":"https://www.paypal.me/MircoWittrien","patreon":"https://www.patreon.com/MircoWittrien","website":"https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatAliases","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ChatAliases/ChatAliases.plugin.js"}*//
2018-10-11 10:21:26 +02:00
2020-02-11 12:58:16 +01:00
var ChatAliases = (_ => {
2020-06-08 20:07:08 +02:00
var settings = {}, amounts = {}, configs = {}, aliases = {};
2020-02-11 12:58:16 +01:00
return class ChatAliases {
getName () {return "ChatAliases";}
2020-06-28 11:29:25 +02:00
getVersion () {return "2.1.8";}
2020-02-11 12:58:16 +01:00
getAuthor () {return "DevilBro";}
2020-02-11 12:58:16 +01:00
getDescription () {return "Allows the user to configure their own chat-aliases which will automatically be replaced before the message is being sent.";}
2019-01-26 22:45:19 +01:00
2020-02-11 12:58:16 +01:00
constructor () {
2020-05-15 11:27:13 +02:00
this.changelog = {
2020-06-28 11:29:25 +02:00
"added":[["Don't replace before send","Added an option to disable the process of aliases being inserted before a message is sent, turning the plugin into a WYSIWYG-esque stylt that only inserts aliases via the autocomplete menu"]]
2020-05-15 11:27:13 +02:00
};
2020-02-11 12:58:16 +01:00
this.patchedModules = {
before: {
ChannelAutoComplete: "render",
ChannelTextAreaForm: "render",
MessageEditor: "render",
Upload: "render"
}
};
}
2018-10-11 10:21:26 +02:00
2020-02-11 12:58:16 +01:00
initConstructor () {
this.css = `
${BDFDB.dotCN.autocompleteicon} {
flex: 0 0 auto;
}
`;
this.defaults = {
configs: {
2020-06-08 20:07:08 +02:00
case: {value:false, description:"Handle the wordvalue case sensitive"},
exact: {value:true, description:"Handle the wordvalue as an exact word and not as part of a word"},
autoc: {value:true, description:"Add this alias in the autocomplete menu (not for RegExp)"},
regex: {value:false, description:"Handle the wordvalue as a RegExp string"},
file: {value:false, description:"Handle the replacevalue as a filepath"}
2019-12-20 14:01:16 +01:00
},
2020-02-11 12:58:16 +01:00
settings: {
2020-07-02 10:42:56 +02:00
replaceBeforeSend: {value:true, inner:false, description:"Replace words with your aliases before a message is sent"},
addContextMenu: {value:true, inner:false, description:"Add a contextMenu entry to faster add new aliases"},
addAutoComplete: {value:true, inner:false, description:"Add an autocomplete-menu for non-RegExp aliases"},
2020-06-08 20:26:00 +02:00
triggerNormal: {value:true, inner:true, description:"Normal Message Textarea"},
triggerEdit: {value:true, inner:true, description:"Edit Message Textarea"},
triggerUpload: {value:true, inner:true, description:"Upload Message Prompt"}
2020-02-11 12:58:16 +01:00
},
amounts: {
2020-06-08 20:07:08 +02:00
minAliasLength: {value:2, min:1, description:"Minimal Character Length to open Autocomplete-Menu:"}
2019-12-20 14:01:16 +01:00
}
2020-02-11 12:58:16 +01:00
};
}
getSettingsPanel (collapseStates = {}) {
if (!window.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return;
let settings = BDFDB.DataUtils.get(this, "settings");
let amounts = BDFDB.DataUtils.get(this, "amounts");
2020-06-08 20:26:00 +02:00
let settingsPanel, settingsItems = [], innerItems = [], subInnerItems = [];
2020-02-11 12:58:16 +01:00
2020-06-08 20:26:00 +02:00
for (let key in settings) (!this.defaults.settings[key].inner ? innerItems : subInnerItems).push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
2019-12-20 14:01:16 +01:00
className: BDFDB.disCN.marginbottom8,
2020-02-11 12:58:16 +01:00
type: "Switch",
plugin: this,
keys: ["settings", key],
label: this.defaults.settings[key].description,
value: settings[key]
}));
2020-03-28 07:55:39 +01:00
for (let key in amounts) innerItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
2020-02-11 12:58:16 +01:00
className: BDFDB.disCN.marginbottom8,
type: "TextInput",
childProps: {
type: "number"
2019-12-20 14:01:16 +01:00
},
2020-02-11 12:58:16 +01:00
plugin: this,
keys: ["amounts", key],
label: this.defaults.amounts[key].description,
basis: "20%",
min: this.defaults.amounts[key].min,
max: this.defaults.amounts[key].max,
value: amounts[key]
}));
2020-06-08 20:26:00 +02:00
innerItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelInner, {
2020-07-02 10:42:56 +02:00
title: "Automatically replace aliases in:",
2020-06-08 20:26:00 +02:00
first: innerItems.length == 0,
last: true,
children: subInnerItems
}));
2020-03-28 07:55:39 +01:00
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
2020-02-11 12:58:16 +01:00
title: "Settings",
collapseStates: collapseStates,
2020-03-28 07:55:39 +01:00
children: innerItems
2020-02-11 12:58:16 +01:00
}));
let values = {wordvalue:"", replacevalue:""};
2020-03-28 07:55:39 +01:00
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
2020-07-02 10:42:56 +02:00
title: "Add new alias",
2020-02-11 12:58:16 +01:00
collapseStates: collapseStates,
children: [
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
type: "Button",
2020-07-02 10:42:56 +02:00
label: "Pick a wordvalue and replacevalue:",
2020-02-11 12:58:16 +01:00
key: "ADDBUTTON",
disabled: !Object.keys(values).every(valuename => values[valuename]),
children: BDFDB.LanguageUtils.LanguageStrings.ADD,
onClick: _ => {
2020-03-28 07:55:39 +01:00
this.saveWord(values.wordvalue, values.replacevalue, settingsPanel.querySelector(".input-replacevalue input[type='file']"));
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
2020-02-11 12:58:16 +01:00
}
}),
this.createInputs(values)
].flat(10).filter(n => n)
}));
2020-06-08 20:07:08 +02:00
if (!BDFDB.ObjectUtils.isEmpty(aliases)) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
2020-07-02 10:42:56 +02:00
title: "Added aliases",
2020-02-11 12:58:16 +01:00
collapseStates: collapseStates,
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsList, {
settings: Object.keys(this.defaults.configs),
2020-06-08 20:07:08 +02:00
data: Object.keys(aliases).map((wordvalue, i) => Object.assign({}, aliases[wordvalue], {
2020-02-11 12:58:16 +01:00
key: wordvalue,
label: wordvalue
})),
renderLabel: data => BDFDB.ReactUtils.createElement("div", {
style: {width: "100%"},
children: [
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, {
value: data.label,
placeholder: data.label,
size: BDFDB.LibraryComponents.TextInput.Sizes.MINI,
maxLength: 100000000000000000000,
onChange: value => {
2020-06-08 20:07:08 +02:00
aliases[value] = aliases[data.label];
delete aliases[data.label];
2020-02-11 12:58:16 +01:00
data.label = value;
2020-06-08 20:07:08 +02:00
BDFDB.DataUtils.save(aliases, this, "words");
2020-02-11 12:58:16 +01:00
}
}),
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, {
value: data.replace,
placeholder: data.replace,
size: BDFDB.LibraryComponents.TextInput.Sizes.MINI,
maxLength: 100000000000000000000,
onChange: value => {
2020-06-08 20:07:08 +02:00
aliases[data.label].replace = value;
BDFDB.DataUtils.save(aliases, this, "words");
2020-02-11 12:58:16 +01:00
}
})
]
}),
onCheckboxChange: (value, instance) => {
2020-06-08 20:07:08 +02:00
aliases[instance.props.cardId][instance.props.settingId] = value;
BDFDB.DataUtils.save(aliases, this, "words");
2020-02-11 12:58:16 +01:00
},
onRemove: (e, instance) => {
2020-06-08 20:07:08 +02:00
delete aliases[instance.props.cardId];
BDFDB.DataUtils.save(aliases, this, "words");
2020-03-28 07:55:39 +01:00
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
2020-02-11 12:58:16 +01:00
}
})
}));
2020-03-28 07:55:39 +01:00
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
2020-02-11 12:58:16 +01:00
title: "Remove All",
collapseStates: collapseStates,
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
type: "Button",
className: BDFDB.disCN.marginbottom8,
color: BDFDB.LibraryComponents.Button.Colors.RED,
2020-07-02 10:42:56 +02:00
label: "Remove all added aliases",
2020-02-11 12:58:16 +01:00
onClick: _ => {
2020-07-02 10:42:56 +02:00
BDFDB.ModalUtils.confirm(this, "Are you sure you want to remove all added aliases?", _ => {
2020-06-08 20:07:08 +02:00
aliases = {};
2020-02-11 12:58:16 +01:00
BDFDB.DataUtils.remove(this, "words");
2020-03-28 07:55:39 +01:00
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
2020-02-11 12:58:16 +01:00
});
},
children: BDFDB.LanguageUtils.LanguageStrings.REMOVE
})
}));
2020-03-28 07:55:39 +01:00
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
2020-02-11 12:58:16 +01:00
title: "Config Guide",
collapseStates: collapseStates,
2020-04-10 17:18:48 +02:00
children: ["Case: Will replace words while comparing lowercase/uppercase. apple => apple, not APPLE or AppLe", "Not Case: Will replace words while ignoring lowercase/uppercase. apple => apple, APPLE and AppLe", "Exact: Will replace words that are exactly the replaceword. apple to pear => applepie stays applepie", "Not Exact: Will replace words anywhere they appear. apple to pear => applepieapple to pearpiepear", "Autoc: Will appear in the Autocomplete Menu (if enabled).", ["Regex: Will treat the entered wordvalue as a regular expression. ", BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Anchor, {href: "https://regexr.com/", children: BDFDB.LanguageUtils.LanguageStrings.HELP + "?"})] , "File: If the replacevalue is a filepath it will try to upload the file located at the filepath."].map(string => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormText, {
2020-02-11 12:58:16 +01:00
type: BDFDB.LibraryComponents.FormComponents.FormTextTypes.DESCRIPTION,
children: string
}))
}));
2020-03-28 07:55:39 +01:00
return settingsPanel = BDFDB.PluginUtils.createSettingsPanel(this, settingsItems);
2020-02-11 12:58:16 +01:00
}
2018-10-11 10:21:26 +02:00
2020-04-11 19:32:58 +02:00
// Legacy
2020-08-21 16:17:47 +02:00
load () {
if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) BDFDB.PluginUtils.load(this);
}
2018-10-11 10:21:26 +02:00
2020-02-11 12:58:16 +01:00
start () {
if (!window.BDFDB) window.BDFDB = {myPlugins:{}};
if (window.BDFDB && window.BDFDB.myPlugins && typeof window.BDFDB.myPlugins == "object") window.BDFDB.myPlugins[this.getName()] = this;
let libraryScript = document.querySelector("head script#BDFDBLibraryScript");
if (!libraryScript || (performance.now() - libraryScript.getAttribute("date")) > 600000) {
if (libraryScript) libraryScript.remove();
libraryScript = document.createElement("script");
libraryScript.setAttribute("id", "BDFDBLibraryScript");
libraryScript.setAttribute("type", "text/javascript");
libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js");
libraryScript.setAttribute("date", performance.now());
libraryScript.addEventListener("load", _ => {this.initialize();});
document.head.appendChild(libraryScript);
}
else if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();
this.startTimeout = setTimeout(_ => {
try {return this.initialize();}
catch (err) {console.error(`%c[${this.getName()}]%c`, "color: #3a71c1; font-weight: 700;", "", "Fatal Error: Could not initiate plugin! " + err);}
}, 30000);
2019-05-26 13:55:26 +02:00
}
2018-10-11 10:21:26 +02:00
2020-02-11 12:58:16 +01:00
initialize () {
if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
if (this.started) return;
BDFDB.PluginUtils.init(this);
2018-10-11 10:21:26 +02:00
2020-06-08 20:07:08 +02:00
aliases = BDFDB.DataUtils.load(this, "words");
2019-01-26 22:45:19 +01:00
2020-06-08 20:07:08 +02:00
this.forceUpdateAll();
2020-02-11 12:58:16 +01:00
}
else console.error(`%c[${this.getName()}]%c`, "color: #3a71c1; font-weight: 700;", "", "Fatal Error: Could not load BD functions!");
2018-10-11 10:21:26 +02:00
}
2020-02-11 12:58:16 +01:00
stop () {
if (window.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) {
this.stopping = true;
2019-10-22 11:37:23 +02:00
2020-06-08 20:07:08 +02:00
this.forceUpdateAll();
2020-02-11 12:58:16 +01:00
BDFDB.PluginUtils.clear(this);
}
2018-10-11 10:21:26 +02:00
}
2020-04-11 19:32:58 +02:00
// Begin of own functions
2018-10-11 10:21:26 +02:00
2020-02-11 12:58:16 +01:00
onSettingsClosed () {
if (this.SettingsUpdated) {
delete this.SettingsUpdated;
2020-06-08 20:07:08 +02:00
this.forceUpdateAll();
2020-02-11 12:58:16 +01:00
}
2019-12-10 13:59:44 +01:00
}
2020-02-11 12:58:16 +01:00
onNativeContextMenu (e) {
if (e.instance.props.value && e.instance.props.value.trim()) {
2020-06-08 20:07:08 +02:00
if ((e.instance.props.type == "NATIVE_TEXT" || e.instance.props.type == "CHANNEL_TEXT_AREA") && settings.addContextMenu) this.injectItem(e, e.instance.props.value.trim());
2020-02-11 12:58:16 +01:00
}
2019-02-06 15:46:34 +01:00
}
2020-02-11 12:58:16 +01:00
onSlateContextMenu (e) {
let text = document.getSelection().toString().trim();
2020-06-08 20:07:08 +02:00
if (text && settings.addContextMenu) this.injectItem(e, text);
2020-02-11 12:58:16 +01:00
}
2020-01-15 10:45:35 +01:00
2020-02-11 12:58:16 +01:00
onMessageContextMenu (e) {
let text = document.getSelection().toString().trim();
2020-06-08 20:07:08 +02:00
if (text && settings.addContextMenu) this.injectItem(e, text);
2020-02-11 12:58:16 +01:00
}
injectItem (e, text) {
2020-05-20 14:40:43 +02:00
let [children, index] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "devmode-copy-id", group: true});
2020-05-20 11:55:46 +02:00
children.splice(index > -1 ? index : children.length, 0, BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuGroup, {
children: BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, {
2020-02-11 12:58:16 +01:00
label: "Add to ChatAliases",
2020-05-19 15:48:04 +02:00
id: BDFDB.ContextMenuUtils.createItemId(this.name, "add-alias"),
2020-02-11 12:58:16 +01:00
action: _ => {
this.openAddModal(text.replace(/\n/g, "\\n").replace(/\r/g, "\\r").replace(/\t/g, "\\t"));
}
})
}));
}
2019-01-26 22:45:19 +01:00
2020-02-11 12:58:16 +01:00
processChannelAutoComplete (e) {
2020-06-08 20:07:08 +02:00
if (settings.addAutoComplete) {
e.instance.state.autocompleteOptions.ALIASES = {
matches: (firstChar, rest, isFirstWord) => {
let currentLastWord = BDFDB.SlateUtils.getCurrentWord(e.instance.props.editorRef.current).word || "";
if (currentLastWord.length >= amounts.minAliasLength) for (let word in aliases) {
let aliasData = aliases[word];
if (!aliasData.regex && aliasData.autoc) {
if (aliasData.exact) {
if (aliasData.case && word.indexOf(currentLastWord) == 0) return true;
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) == 0) return true;
}
else {
if (aliasData.case && word.indexOf(currentLastWord) > -1) return true;
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) > -1) return true;
}
2020-02-11 12:58:16 +01:00
}
2020-06-08 20:07:08 +02:00
}
return false;
},
queryResults: (rest) => {
let currentLastWord = BDFDB.SlateUtils.getCurrentWord(e.instance.props.editorRef.current).word || "";
let matches = [];
for (let word in aliases) {
if (matches.length >= BDFDB.DiscordConstants.MAX_AUTOCOMPLETE_RESULTS) break;
let aliasData = Object.assign({word}, aliases[word]);
if (!aliasData.regex && aliasData.autoc) {
if (aliasData.exact) {
if (aliasData.case && word.indexOf(currentLastWord) == 0) matches.push(aliasData);
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) == 0) matches.push(aliasData);
}
else {
if (aliasData.case && word.indexOf(currentLastWord) > -1) matches.push(aliasData);
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) > -1) matches.push(aliasData);
}
2020-02-11 12:58:16 +01:00
}
2019-12-20 14:01:16 +01:00
}
2020-06-08 20:07:08 +02:00
if (matches.length) return {aliases: matches};
},
renderResults: (rest, currentSelected, setSelected, chooseSelected, autocompletes) => {
return [
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.AutocompleteItems.Title, {
title: [
"Aliases: ",
BDFDB.ReactUtils.createElement("strong", {
children: BDFDB.SlateUtils.getCurrentWord(e.instance.props.editorRef.current).word || ""
})
]
}),
autocompletes.aliases.map((aliasData, i) => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.AutocompleteItems.Generic, {
onClick: chooseSelected,
onHover: setSelected,
index: i,
selected: currentSelected === i,
alias: aliasData,
text: aliasData.word,
description: aliasData.replace,
}))
].flat(10).filter(n => n);
},
getPlainText: (eventOrIndex, autocompletes) => {
let aliasData = eventOrIndex._targetInst ? eventOrIndex._targetInst.memoizedProps.alias : typeof eventOrIndex == "number" && autocompletes.aliases[eventOrIndex];
return aliasData.word;
},
getRawText: (eventOrIndex, autocompletes) => {
let aliasData = eventOrIndex._targetInst ? eventOrIndex._targetInst.memoizedProps.alias : typeof eventOrIndex == "number" && autocompletes.aliases[eventOrIndex];
return aliasData.file ? aliasData.word : BDFDB.StringUtils.insertNRST(aliasData.replace);
2020-02-11 12:58:16 +01:00
}
2020-06-08 20:07:08 +02:00
};
if (e.instance.state.autocompleteType == "COMMAND" && BDFDB.ArrayUtils.is(e.instance.state.autocompletes.commands)) {
for (let i in e.instance.state.autocompletes.commands) if (e.instance.state.autocompletes.commands[i].alias) e.instance.state.autocompletes.commands[i] = null;
e.instance.state.autocompletes.commands = e.instance.state.autocompletes.commands.filter(n => n);
2020-02-11 12:58:16 +01:00
let currentLastWord = BDFDB.SlateUtils.getCurrentWord(e.instance.props.editorRef.current).word || "";
2020-06-08 20:07:08 +02:00
let commandAliases = BDFDB.ObjectUtils.filter(aliases, key => key.startsWith("/"), true);
2020-06-09 19:41:53 +02:00
if (currentLastWord.length >= amounts.minAliasLength) for (let word in commandAliases) {
2020-06-08 20:07:08 +02:00
if (e.instance.state.autocompletes.commands.length >= BDFDB.DiscordConstants.MAX_AUTOCOMPLETE_RESULTS) break;
let aliasData = commandAliases[word];
let command = {command: word.slice(1), description: BDFDB.StringUtils.insertNRST(aliasData.replace), alias:true};
2020-05-22 20:15:29 +02:00
if (!aliasData.regex && aliasData.autoc) {
if (aliasData.exact) {
2020-06-08 20:07:08 +02:00
if (aliasData.case && word.indexOf(currentLastWord) == 0) e.instance.state.autocompletes.commands.push(command);
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) == 0) e.instance.state.autocompletes.commands.push(command);
2020-02-11 12:58:16 +01:00
}
else {
2020-06-08 20:07:08 +02:00
if (aliasData.case && word.indexOf(currentLastWord) > -1) e.instance.state.autocompletes.commands.push(command);
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) > -1) e.instance.state.autocompletes.commands.push(command);
2020-02-11 12:58:16 +01:00
}
2019-12-20 14:01:16 +01:00
}
}
2019-12-21 01:14:53 +01:00
}
2018-10-11 10:21:26 +02:00
}
2020-02-11 12:58:16 +01:00
}
processChannelTextAreaForm (e) {
if (!BDFDB.ModuleUtils.isPatched(this, e.instance, "handleSendMessage")) BDFDB.ModuleUtils.patch(this, e.instance, "handleSendMessage", {before: e2 => {
2020-06-08 20:26:00 +02:00
if (settings.triggerNormal) this.handleSubmit(e, e2, 0);
2020-03-28 07:41:31 +01:00
}}, {force: true, noCache: true});
2020-02-11 12:58:16 +01:00
}
processMessageEditor (e) {
if (!BDFDB.ModuleUtils.isPatched(this, e.instance, "onSubmit")) BDFDB.ModuleUtils.patch(this, e.instance, "onSubmit", {before: e2 => {
2020-06-08 20:26:00 +02:00
if (settings.triggerEdit) this.handleSubmit(e, e2, 0);
2020-03-28 07:41:31 +01:00
}}, {force: true, noCache: true});
2020-02-11 12:58:16 +01:00
}
processUpload (e) {
if (!BDFDB.ModuleUtils.isPatched(this, e.instance, "submitUpload")) BDFDB.ModuleUtils.patch(this, e.instance, "submitUpload", {before: e2 => {
2020-06-08 20:26:00 +02:00
if (settings.triggerUpload) this.handleSubmit(e, e2, 1);
2020-03-28 07:41:31 +01:00
}}, {force: true, noCache: true});
2020-02-11 12:58:16 +01:00
}
2020-06-08 20:07:08 +02:00
forceUpdateAll () {
settings = BDFDB.DataUtils.get(this, "settings");
amounts = BDFDB.DataUtils.get(this, "amounts");
configs = BDFDB.DataUtils.get(this, "configs");
BDFDB.ModuleUtils.forceAllUpdates(this);
}
2020-02-11 12:58:16 +01:00
handleSubmit (e, e2, textIndex) {
2020-06-28 11:29:25 +02:00
if (!settings.replaceBeforeSend || BDFDB.LibraryModules.SlowmodeUtils.getSlowmodeCooldownGuess(e.instance.props.channel.id) > 0) return;
2020-02-11 12:58:16 +01:00
let messageData = this.formatText(e2.methodArguments[textIndex]);
if (messageData) {
if (messageData.text != null) {
e2.methodArguments[textIndex] = messageData.text;
2020-05-15 12:58:08 +02:00
e.instance.props.textValue = "";
if (e.instance.props.richValue) e.instance.props.richValue = BDFDB.SlateUtils.copyRichValue("", e.instance.props.richValue);
if (e.instance.state) {
e.instance.state.textValue = "";
if (e.instance.state.richValue) e.instance.state.richValue = BDFDB.SlateUtils.copyRichValue("", e.instance.state.richValue);
}
2020-05-15 11:27:13 +02:00
BDFDB.ReactUtils.forceUpdate(e.instance);
2018-10-11 10:21:26 +02:00
}
2020-02-11 12:58:16 +01:00
if (messageData.files.length > 0 && (BDFDB.DMUtils.isDMChannel(e.instance.props.channel.id) || BDFDB.UserUtils.can("ATTACH_FILES"))) {
BDFDB.LibraryModules.UploadUtils.instantBatchUpload(e.instance.props.channel.id, messageData.files);
2019-12-21 01:14:53 +01:00
}
2019-12-21 11:35:33 +01:00
}
2018-10-11 10:21:26 +02:00
}
2020-02-11 12:58:16 +01:00
formatText (text) {
text = text.replace(/([\n\t\r])/g, " $1 ");
2020-05-22 20:15:29 +02:00
let newText = [], files = [], wordAliases = {}, multiAliases = {};
2020-06-08 20:07:08 +02:00
for (let word in aliases) {
if (!aliases[word].regex && word.indexOf(" ") == -1) wordAliases[word] = aliases[word];
else multiAliases[word] = aliases[word];
2020-02-11 12:58:16 +01:00
}
for (let word of text.trim().split(" ")) {
newText.push(this.useAliases(word, wordAliases, files, true));
}
newText = newText.length == 1 ? newText[0] : newText.join(" ");
newText = newText.replace(/ ([\n\t\r]) /g, "$1");
newText = this.useAliases(newText, multiAliases, files, false);
return {text:newText, files};
2018-10-11 10:21:26 +02:00
}
2020-05-22 20:15:29 +02:00
useAliases (string, aliases, files, singleWord) {
2020-02-11 12:58:16 +01:00
for (let word in aliases) {
2020-05-22 20:15:29 +02:00
let aliasData = aliases[word];
let escpAlias = aliasData.regex ? word : BDFDB.StringUtils.regEscape(word);
2020-02-11 12:58:16 +01:00
let result = true, replaced = false, tempstring1 = string, tempstring2 = "";
2020-05-22 20:15:29 +02:00
let regString = aliasData.exact ? "^" + escpAlias + "$" : escpAlias;
2020-02-11 12:58:16 +01:00
while (result != null) {
2020-05-22 20:15:29 +02:00
result = new RegExp(regString, (aliasData.case ? "" : "i") + (aliasData.exact ? "" : "g")).exec(tempstring1);
2020-02-11 12:58:16 +01:00
if (result) {
replaced = true;
2020-05-22 20:15:29 +02:00
let replace = aliasData.file ? "" : BDFDB.StringUtils.insertNRST(aliasData.replace);
2020-02-11 12:58:16 +01:00
if (result.length > 1) for (let i = 1; i < result.length; i++) replace = replace.replace(new RegExp("\\\\" + i + "|\\$" + i, "g"), result[i]);
tempstring2 += tempstring1.slice(0, result.index + result[0].length).replace(result[0], replace);
tempstring1 = tempstring1.slice(result.index + result[0].length);
2020-05-22 20:15:29 +02:00
if (aliasData.file && typeof aliasData.filedata == "string") {
let filedata = JSON.parse(aliasData.filedata);
2020-02-11 12:58:16 +01:00
files.push(new File([Uint8Array.from(atob(filedata.data), c => c.charCodeAt(0))], filedata.name, {type:filedata.type}));
}
2020-05-22 20:15:29 +02:00
if (aliasData.regex && regString.indexOf("^") == 0) result = null;
2018-10-11 10:21:26 +02:00
}
2020-02-11 12:58:16 +01:00
if (!result) tempstring2 += tempstring1;
}
if (replaced) {
string = tempstring2;
2020-05-22 20:15:29 +02:00
if (singleWord) break;
2018-10-11 10:21:26 +02:00
}
}
2020-02-11 12:58:16 +01:00
return string;
2018-10-11 10:21:26 +02:00
}
2019-09-04 12:34:02 +02:00
2020-02-11 12:58:16 +01:00
openAddModal (wordvalue) {
let values = {
wordvalue,
replacevalue: ""
};
BDFDB.ModalUtils.open(this, {
size: "MEDIUM",
header: "Add to ChatAliases",
subheader: "",
children: [
this.createInputs(values),
BDFDB.ArrayUtils.remove(Object.keys(this.defaults.configs), "file").map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
type: "Switch",
className: BDFDB.disCN.marginbottom8 + " input-config" + key,
label: this.defaults.configs[key].description,
value: this.defaults.configs[key].value
}))
].flat(10).filter(n => n),
buttons: [{
key: "ADDBUTTON",
disabled: !Object.keys(values).every(valuename => values[valuename]),
contents: BDFDB.LanguageUtils.LanguageStrings.ADD,
color: "BRAND",
close: true,
click: modal => {
let configs = {};
for (let key in this.defaults.configs) {
let configinput = modal.querySelector(`.input-config${key} ${BDFDB.dotCN.switchinner}`);
if (configinput) configs[key] = configinput.checked;
}
this.saveWord(values.wordvalue, values.replacevalue, modal.querySelector(".input-replacevalue input[type='file']"), configs);
2019-12-20 14:01:16 +01:00
}
2020-02-11 12:58:16 +01:00
}]
});
}
createInputs (values) {
2020-07-02 10:42:56 +02:00
return [
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, {
title: "Replace:",
className: BDFDB.disCN.marginbottom8 + " input-wordvalue",
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, {
value: values.wordvalue,
placeholder: values.wordvalue,
errorMessage: !values.wordvalue && "Choose a wordvalue" || aliases[values.wordvalue] && "Wordvalue already used, saving will overwrite old alias",
onChange: (value, instance) => {
values.wordvalue = value.trim();
if (!values.wordvalue) instance.props.errorMessage = "Choose a wordvalue";
else if (aliases[values.wordvalue]) instance.props.errorMessage = "Wordvalue already used, saving will overwrite old alias";
else delete instance.props.errorMessage;
let addButtonIns = BDFDB.ReactUtils.findOwner(BDFDB.ReactUtils.findOwner(instance, {name:["BDFDB_Modal", "BDFDB_SettingsPanel"], up:true}), {key:"ADDBUTTON"});
if (addButtonIns) {
addButtonIns.props.disabled = !Object.keys(values).every(valuename => values[valuename]);
BDFDB.ReactUtils.forceUpdate(addButtonIns);
}
2020-02-11 12:58:16 +01:00
}
2020-07-02 10:42:56 +02:00
})
}),
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, {
title: "With:",
className: BDFDB.disCN.marginbottom8 + " input-replacevalue",
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, {
type: "file",
useFilePath: true,
value: values.replacevalue,
placeholder: values.replacevalue,
autoFocus: true,
errorMessage: !values.replacevalue && "Choose a replacevalue",
onChange: (value, instance) => {
values.replacevalue = value.trim();
if (!values.replacevalue) instance.props.errorMessage = "Choose a replacevalue";
else delete instance.props.errorMessage;
let addButtonIns = BDFDB.ReactUtils.findOwner(BDFDB.ReactUtils.findOwner(instance, {name:["BDFDB_Modal", "BDFDB_SettingsPanel"], up:true}), {key:"ADDBUTTON"});
if (addButtonIns) {
addButtonIns.props.disabled = !Object.keys(values).every(valuename => values[valuename]);
BDFDB.ReactUtils.forceUpdate(addButtonIns);
}
}
})
2020-02-11 12:58:16 +01:00
})
2020-07-02 10:42:56 +02:00
];
2020-02-11 12:58:16 +01:00
}
2019-09-04 12:34:02 +02:00
2020-06-08 20:07:08 +02:00
saveWord (wordvalue, replacevalue, fileselection, aliasConfigs = configs) {
2020-02-11 12:58:16 +01:00
if (!wordvalue || !replacevalue || !fileselection) return;
2020-06-08 20:07:08 +02:00
let filedata = null;
2020-02-11 12:58:16 +01:00
if (fileselection.files && fileselection.files[0] && BDFDB.LibraryRequires.fs.existsSync(replacevalue)) {
filedata = JSON.stringify({
data: BDFDB.LibraryRequires.fs.readFileSync(replacevalue).toString("base64"),
name: fileselection.files[0].name,
type: fileselection.files[0].type
});
}
2020-06-08 20:07:08 +02:00
aliases[wordvalue] = {
2020-02-11 12:58:16 +01:00
replace: replacevalue,
filedata: filedata,
2020-06-08 20:07:08 +02:00
case: aliasConfigs.case,
exact: wordvalue.indexOf(" ") > -1 ? false : aliasConfigs.exact,
autoc: aliasConfigs.regex ? false : aliasConfigs.autoc,
regex: aliasConfigs.regex,
2020-02-11 12:58:16 +01:00
file: filedata != null
};
2020-06-08 20:07:08 +02:00
BDFDB.DataUtils.save(aliases, this, "words");
2019-12-20 14:01:16 +01:00
}
2019-02-06 15:46:34 +01:00
}
2020-07-26 16:39:51 +02:00
})();
module.exports = ChatAliases;