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-09-19 20:49:33 +02:00
|
|
|
module.exports = (_ => {
|
2020-10-09 21:09:35 +02:00
|
|
|
const config = {
|
2020-09-19 20:49:33 +02:00
|
|
|
"info": {
|
|
|
|
"name": "ChatAliases",
|
|
|
|
"author": "DevilBro",
|
2020-09-26 18:18:52 +02:00
|
|
|
"version": "2.1.9",
|
2020-10-16 10:25:30 +02:00
|
|
|
"description": "Allow the user to configure their own chat-aliases which will automatically be replaced before the message is being sent"
|
2020-09-26 18:18:52 +02:00
|
|
|
},
|
|
|
|
"changeLog": {
|
|
|
|
"fixed": {
|
|
|
|
"Autocomplete Menu": "Works again"
|
|
|
|
}
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
};
|
2020-10-09 21:09:35 +02:00
|
|
|
return !window.BDFDB_Global || (!window.BDFDB_Global.loaded && !window.BDFDB_Global.started) ? class {
|
2020-09-19 20:49:33 +02:00
|
|
|
getName () {return config.info.name;}
|
|
|
|
getAuthor () {return config.info.author;}
|
|
|
|
getVersion () {return config.info.version;}
|
|
|
|
getDescription () {return config.info.description;}
|
|
|
|
|
2020-10-09 21:09:35 +02:00
|
|
|
load() {
|
2020-09-19 20:49:33 +02:00
|
|
|
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;},
|
2020-09-20 08:15:13 +02:00
|
|
|
onConfirm: _ => {
|
|
|
|
delete window.BDFDB_Global.downloadModal;
|
|
|
|
require("request").get("https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js", (e, r, b) => {
|
|
|
|
if (!e && b && b.indexOf(`//META{"name":"`) > -1) require("fs").writeFile(require("path").join(BdApi.Plugins.folder, "0BDFDB.plugin.js"), b, _ => {});
|
|
|
|
else BdApi.alert("Error", "Could not download BDFDB library plugin, try again some time later.");
|
|
|
|
});
|
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
if (!window.BDFDB_Global.pluginQueue.includes(config.info.name)) window.BDFDB_Global.pluginQueue.push(config.info.name);
|
2020-10-09 21:09:35 +02:00
|
|
|
}
|
|
|
|
start() {this.load();}
|
|
|
|
stop() {}
|
|
|
|
} : (([Plugin, BDFDB]) => {
|
2020-09-26 18:18:52 +02:00
|
|
|
var settings = {}, amounts = {}, configs = {}, aliases = {}, commandAliases = {};
|
2020-09-19 20:49:33 +02:00
|
|
|
|
2020-10-09 21:09:35 +02:00
|
|
|
return class ChatAliases extends Plugin {
|
2020-09-19 20:49:33 +02:00
|
|
|
onLoad() {
|
|
|
|
this.defaults = {
|
|
|
|
configs: {
|
|
|
|
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"}
|
2020-02-11 12:58:16 +01:00
|
|
|
},
|
2020-09-19 20:49:33 +02:00
|
|
|
settings: {
|
|
|
|
replaceBeforeSend: {value:true, inner:false, description:"Replace words with your aliases before a message is sent"},
|
2020-09-26 18:18:52 +02:00
|
|
|
addContextMenu: {value:true, inner:false, description:"Add a contextmenu entry to faster add new aliases"},
|
2020-09-19 20:49:33 +02:00
|
|
|
addAutoComplete: {value:true, inner:false, description:"Add an autocomplete-menu for non-RegExp aliases"},
|
|
|
|
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
|
|
|
},
|
2020-09-19 20:49:33 +02:00
|
|
|
amounts: {
|
|
|
|
minAliasLength: {value:2, min:1, description:"Minimal Character Length to open Autocomplete-Menu:"}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
this.patchedModules = {
|
|
|
|
before: {
|
|
|
|
ChannelTextAreaForm: "render",
|
|
|
|
MessageEditor: "render",
|
|
|
|
Upload: "render"
|
2020-09-26 18:18:52 +02:00
|
|
|
},
|
|
|
|
after: {
|
|
|
|
ChannelAutoComplete: "render"
|
2020-09-19 20:49:33 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
this.css = `
|
|
|
|
${BDFDB.dotCN.autocompleteicon} {
|
|
|
|
flex: 0 0 auto;
|
|
|
|
}
|
|
|
|
`;
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
|
|
|
|
onStart() {
|
2020-06-08 20:07:08 +02:00
|
|
|
aliases = BDFDB.DataUtils.load(this, "words");
|
2020-09-26 18:18:52 +02:00
|
|
|
commandAliases = BDFDB.ObjectUtils.filter(aliases, key => key.startsWith("/"), true);
|
|
|
|
|
|
|
|
if (BDFDB.LibraryModules.AutocompleteOptions && BDFDB.LibraryModules.AutocompleteOptions.AUTOCOMPLETE_OPTIONS) {
|
|
|
|
BDFDB.LibraryModules.AutocompleteOptions.AUTOCOMPLETE_OPTIONS.ALIASES = {
|
|
|
|
autoSelect: true,
|
|
|
|
getPlainText: (eventOrIndex, config, autocompletes) => {
|
|
|
|
let aliasData = eventOrIndex._targetInst ? eventOrIndex._targetInst.memoizedProps.alias : typeof eventOrIndex == "number" && autocompletes.aliases[eventOrIndex];
|
|
|
|
return aliasData.word;
|
|
|
|
},
|
|
|
|
getRawText: (eventOrIndex, config, 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);
|
|
|
|
},
|
|
|
|
getSentinel: () => {
|
|
|
|
return "";
|
|
|
|
},
|
|
|
|
matches: (channel, what, wordLowercase, what2, config, rawValue) => {
|
|
|
|
let currentLastWord = BDFDB.StringUtils.findMatchCaseless(wordLowercase, rawValue, true);
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
queryResults: (channel, wordLowercase, config, rawValue) => {
|
|
|
|
let currentLastWord = BDFDB.StringUtils.findMatchCaseless(wordLowercase, rawValue, true);
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (matches.length) return {aliases: matches};
|
|
|
|
},
|
|
|
|
renderResults: (channel, wordLowercase, currentSelected, setSelected, chooseSelected, config, autocompletes) => {
|
|
|
|
return [
|
|
|
|
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.AutocompleteItems.Title, {
|
|
|
|
title: [
|
|
|
|
"Aliases: ",
|
|
|
|
BDFDB.ReactUtils.createElement("strong", {
|
|
|
|
children: wordLowercase
|
|
|
|
})
|
|
|
|
]
|
|
|
|
}),
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
BDFDB.PatchUtils.patch(this, BDFDB.LibraryModules.AutocompleteOptions.AUTOCOMPLETE_OPTIONS.COMMANDS, "queryResults", {after: e => {
|
|
|
|
let currentLastWord = BDFDB.StringUtils.findMatchCaseless(e.thisObject.getSentinel() + e.methodArguments[1], e.methodArguments[3], true);
|
|
|
|
if (currentLastWord.length >= amounts.minAliasLength) for (let word in commandAliases) {
|
|
|
|
if (e.returnValue.commands.length >= BDFDB.DiscordConstants.MAX_AUTOCOMPLETE_RESULTS) break;
|
|
|
|
let aliasData = commandAliases[word];
|
|
|
|
let name = word.slice(1);
|
|
|
|
let command = {
|
|
|
|
id: "chatalias-" + name,
|
|
|
|
name: name,
|
|
|
|
description: BDFDB.StringUtils.insertNRST(aliasData.replace)
|
|
|
|
};
|
|
|
|
if (!aliasData.regex && aliasData.autoc) {
|
|
|
|
if (aliasData.exact) {
|
|
|
|
if (aliasData.case && word.indexOf(currentLastWord) == 0) e.returnValue.commands.push(command);
|
|
|
|
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) == 0) e.returnValue.commands.push(command);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (aliasData.case && word.indexOf(currentLastWord) > -1) e.returnValue.commands.push(command);
|
|
|
|
else if (!aliasData.case && word.toLowerCase().indexOf(currentLastWord.toLowerCase()) > -1) e.returnValue.commands.push(command);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}});
|
|
|
|
}
|
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
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
|
|
|
|
onStop() {
|
2020-09-26 18:18:52 +02:00
|
|
|
if (BDFDB.LibraryModules.AutocompleteOptions && BDFDB.LibraryModules.AutocompleteOptions.AUTOCOMPLETE_OPTIONS) {
|
|
|
|
delete BDFDB.LibraryModules.AutocompleteOptions.AUTOCOMPLETE_OPTIONS.ALIASES;
|
|
|
|
}
|
2020-06-08 20:07:08 +02:00
|
|
|
this.forceUpdateAll();
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
getSettingsPanel (collapseStates = {}) {
|
|
|
|
let settingsPanel, settingsItems = [];
|
|
|
|
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
|
|
|
|
title: "Settings",
|
|
|
|
collapseStates: collapseStates,
|
|
|
|
children: Object.keys(settings).map(key => !this.defaults.settings[key].inner && BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
|
|
|
|
type: "Switch",
|
|
|
|
plugin: this,
|
|
|
|
keys: ["settings", key],
|
|
|
|
label: this.defaults.settings[key].description,
|
|
|
|
value: settings[key]
|
|
|
|
})).concat(Object.keys(amounts).map(key => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
|
|
|
|
type: "TextInput",
|
|
|
|
childProps: {
|
|
|
|
type: "number"
|
|
|
|
},
|
|
|
|
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]
|
|
|
|
}))).concat(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsPanelInner, {
|
|
|
|
title: "Automatically replace aliases in:",
|
|
|
|
last: true,
|
|
|
|
children: Object.keys(settings).map(key => this.defaults.settings[key].inner && BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
|
|
|
|
type: "Switch",
|
|
|
|
plugin: this,
|
|
|
|
keys: ["settings", key],
|
|
|
|
label: this.defaults.settings[key].description,
|
|
|
|
value: settings[key]
|
|
|
|
}))
|
|
|
|
}))
|
|
|
|
}));
|
|
|
|
let values = {wordvalue:"", replacevalue:""};
|
|
|
|
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
|
|
|
|
title: "Add new alias",
|
|
|
|
collapseStates: collapseStates,
|
|
|
|
children: [
|
|
|
|
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
|
|
|
|
type: "Button",
|
|
|
|
label: "Pick a wordvalue and replacevalue:",
|
|
|
|
key: "ADDBUTTON",
|
|
|
|
disabled: !Object.keys(values).every(valuename => values[valuename]),
|
|
|
|
children: BDFDB.LanguageUtils.LanguageStrings.ADD,
|
|
|
|
onClick: _ => {
|
|
|
|
this.saveWord(values.wordvalue, values.replacevalue, settingsPanel.querySelector(".input-replacevalue input[type='file']"));
|
|
|
|
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
this.createInputs(values)
|
|
|
|
].flat(10).filter(n => n)
|
|
|
|
}));
|
|
|
|
if (!BDFDB.ObjectUtils.isEmpty(aliases)) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
|
|
|
|
title: "Added aliases",
|
|
|
|
collapseStates: collapseStates,
|
|
|
|
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsList, {
|
|
|
|
settings: Object.keys(this.defaults.configs),
|
|
|
|
data: Object.keys(aliases).map((wordvalue, i) => Object.assign({}, aliases[wordvalue], {
|
|
|
|
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 => {
|
|
|
|
aliases[value] = aliases[data.label];
|
|
|
|
delete aliases[data.label];
|
|
|
|
data.label = value;
|
|
|
|
BDFDB.DataUtils.save(aliases, this, "words");
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.TextInput, {
|
|
|
|
value: data.replace,
|
|
|
|
placeholder: data.replace,
|
|
|
|
size: BDFDB.LibraryComponents.TextInput.Sizes.MINI,
|
|
|
|
maxLength: 100000000000000000000,
|
|
|
|
onChange: value => {
|
|
|
|
aliases[data.label].replace = value;
|
|
|
|
BDFDB.DataUtils.save(aliases, this, "words");
|
|
|
|
}
|
|
|
|
})
|
|
|
|
]
|
|
|
|
}),
|
|
|
|
onCheckboxChange: (value, instance) => {
|
|
|
|
aliases[instance.props.cardId][instance.props.settingId] = value;
|
|
|
|
BDFDB.DataUtils.save(aliases, this, "words");
|
|
|
|
},
|
|
|
|
onRemove: (e, instance) => {
|
|
|
|
delete aliases[instance.props.cardId];
|
|
|
|
BDFDB.DataUtils.save(aliases, this, "words");
|
|
|
|
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}));
|
|
|
|
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
|
|
|
|
title: "Remove All",
|
|
|
|
collapseStates: collapseStates,
|
|
|
|
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsItem, {
|
|
|
|
type: "Button",
|
|
|
|
className: BDFDB.disCN.marginbottom8,
|
|
|
|
color: BDFDB.LibraryComponents.Button.Colors.RED,
|
|
|
|
label: "Remove all added aliases",
|
|
|
|
onClick: _ => {
|
|
|
|
BDFDB.ModalUtils.confirm(this, "Are you sure you want to remove all added aliases?", _ => {
|
|
|
|
aliases = {};
|
2020-09-26 18:18:52 +02:00
|
|
|
commandAliases = {};
|
2020-09-19 20:49:33 +02:00
|
|
|
BDFDB.DataUtils.remove(this, "words");
|
|
|
|
BDFDB.PluginUtils.refreshSettingsPanel(this, settingsPanel, collapseStates);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
children: BDFDB.LanguageUtils.LanguageStrings.REMOVE
|
|
|
|
})
|
|
|
|
}));
|
|
|
|
settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.CollapseContainer, {
|
|
|
|
title: "Config Guide",
|
|
|
|
collapseStates: collapseStates,
|
|
|
|
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, {
|
|
|
|
type: BDFDB.LibraryComponents.FormComponents.FormTextTypes.DESCRIPTION,
|
|
|
|
children: string
|
|
|
|
}))
|
|
|
|
}));
|
|
|
|
|
|
|
|
return settingsPanel = BDFDB.PluginUtils.createSettingsPanel(this, settingsItems);
|
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
onSettingsClosed () {
|
|
|
|
if (this.SettingsUpdated) {
|
|
|
|
delete this.SettingsUpdated;
|
|
|
|
this.forceUpdateAll();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
forceUpdateAll () {
|
|
|
|
settings = BDFDB.DataUtils.get(this, "settings");
|
|
|
|
amounts = BDFDB.DataUtils.get(this, "amounts");
|
|
|
|
configs = BDFDB.DataUtils.get(this, "configs");
|
|
|
|
|
|
|
|
BDFDB.PatchUtils.forceAllUpdates(this);
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2019-12-10 13:59:44 +01:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
onNativeContextMenu (e) {
|
|
|
|
if (e.instance.props.value && e.instance.props.value.trim()) {
|
|
|
|
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-09-19 20:49:33 +02:00
|
|
|
onSlateContextMenu (e) {
|
|
|
|
let text = document.getSelection().toString().trim();
|
|
|
|
if (text && settings.addContextMenu) this.injectItem(e, text);
|
|
|
|
}
|
2020-01-15 10:45:35 +01:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
onMessageContextMenu (e) {
|
|
|
|
let text = document.getSelection().toString().trim();
|
|
|
|
if (text && settings.addContextMenu) this.injectItem(e, text);
|
|
|
|
}
|
|
|
|
|
|
|
|
injectItem (e, text) {
|
|
|
|
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: "Add to ChatAliases",
|
|
|
|
id: BDFDB.ContextMenuUtils.createItemId(this.name, "add-alias"),
|
|
|
|
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-09-19 20:49:33 +02:00
|
|
|
processChannelAutoComplete (e) {
|
2020-09-26 18:18:52 +02:00
|
|
|
if (false && settings.addAutoComplete) {
|
2019-12-21 01:14:53 +01:00
|
|
|
}
|
2018-10-11 10:21:26 +02:00
|
|
|
}
|
2020-06-08 20:07:08 +02:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
processChannelTextAreaForm (e) {
|
|
|
|
if (!BDFDB.PatchUtils.isPatched(this, e.instance, "handleSendMessage")) BDFDB.PatchUtils.patch(this, e.instance, "handleSendMessage", {before: e2 => {
|
|
|
|
if (settings.triggerNormal) this.handleSubmit(e, e2, 0);
|
|
|
|
}}, {force: true, noCache: true});
|
2019-12-21 11:35:33 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
|
|
|
|
processMessageEditor (e) {
|
|
|
|
if (!BDFDB.PatchUtils.isPatched(this, e.instance, "onSubmit")) BDFDB.PatchUtils.patch(this, e.instance, "onSubmit", {before: e2 => {
|
|
|
|
if (settings.triggerEdit) this.handleSubmit(e, e2, 0);
|
|
|
|
}}, {force: true, noCache: true});
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
|
|
|
|
processUpload (e) {
|
|
|
|
if (!BDFDB.PatchUtils.isPatched(this, e.instance, "submitUpload")) BDFDB.PatchUtils.patch(this, e.instance, "submitUpload", {before: e2 => {
|
|
|
|
if (settings.triggerUpload) this.handleSubmit(e, e2, 1);
|
|
|
|
}}, {force: true, noCache: true});
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
|
|
|
|
handleSubmit (e, e2, textIndex) {
|
|
|
|
if (!settings.replaceBeforeSend || BDFDB.LibraryModules.SlowmodeUtils.getSlowmodeCooldownGuess(e.instance.props.channel.id) > 0) return;
|
|
|
|
let messageData = this.formatText(e2.methodArguments[textIndex]);
|
|
|
|
if (messageData) {
|
|
|
|
if (messageData.text != null) {
|
|
|
|
e2.methodArguments[textIndex] = messageData.text;
|
|
|
|
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-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
BDFDB.ReactUtils.forceUpdate(e.instance);
|
|
|
|
}
|
|
|
|
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);
|
2018-10-11 10:21:26 +02:00
|
|
|
}
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
formatText (text) {
|
|
|
|
text = text.replace(/([\n\t\r])/g, " $1 ");
|
|
|
|
let newText = [], files = [], wordAliases = {}, multiAliases = {};
|
|
|
|
for (let word in aliases) {
|
|
|
|
if (!aliases[word].regex && word.indexOf(" ") == -1) wordAliases[word] = aliases[word];
|
|
|
|
else multiAliases[word] = aliases[word];
|
|
|
|
}
|
|
|
|
for (let word of text.trim().split(" ")) {
|
|
|
|
newText.push(this.useAliases(word, wordAliases, files, true));
|
2018-10-11 10:21:26 +02:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
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
|
|
|
}
|
2019-09-04 12:34:02 +02:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
useAliases (string, aliases, files, singleWord) {
|
|
|
|
for (let word in aliases) {
|
|
|
|
let result = true, replaced = false, tempString1 = string, tempString2 = "";
|
|
|
|
let config = aliases[word];
|
|
|
|
let escpAlias = config.regex ? word : BDFDB.StringUtils.regEscape(word);
|
|
|
|
let regString = config.exact ? "^" + escpAlias + "$" : escpAlias;
|
|
|
|
while (result != null) {
|
|
|
|
result = new RegExp(regString, `${config.case ? "" : "i"}${config.exact ? "" : "g"}`).exec(tempString1);
|
|
|
|
if (result) {
|
|
|
|
replaced = true;
|
|
|
|
let replace = config.file ? "" : BDFDB.StringUtils.insertNRST(config.replace);
|
|
|
|
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);
|
|
|
|
if (config.file && typeof config.filedata == "string") {
|
|
|
|
let filedata = JSON.parse(config.filedata);
|
|
|
|
files.push(new File([Uint8Array.from(atob(filedata.data), c => c.charCodeAt(0))], filedata.name, {type:filedata.type}));
|
|
|
|
}
|
|
|
|
if (config.regex && regString.indexOf("^") == 0) result = null;
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
if (!result) tempString2 += tempString1;
|
2019-12-20 14:01:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
if (replaced) {
|
|
|
|
string = tempString2;
|
|
|
|
if (singleWord) break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return string;
|
|
|
|
}
|
|
|
|
|
|
|
|
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",
|
2020-10-14 21:08:41 +02:00
|
|
|
className: "input-config" + key,
|
2020-09-19 20:49:33 +02:00
|
|
|
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;
|
2020-07-02 10:42:56 +02:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
this.saveWord(values.wordvalue, values.replacevalue, modal.querySelector(".input-replacevalue input[type='file']"), configs);
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
}]
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
createInputs (values) {
|
|
|
|
return [
|
|
|
|
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, {
|
|
|
|
title: "Replace:",
|
2020-10-14 21:08:41 +02:00
|
|
|
className: "input-wordvalue",
|
2020-09-19 20:49:33 +02:00
|
|
|
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-07-02 10:42:56 +02:00
|
|
|
}
|
2020-09-19 20:49:33 +02:00
|
|
|
})
|
|
|
|
}),
|
|
|
|
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.FormComponents.FormItem, {
|
|
|
|
title: "With:",
|
2020-10-14 21:08:41 +02:00
|
|
|
className: "input-replacevalue",
|
2020-09-19 20:49:33 +02:00
|
|
|
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-07-02 10:42:56 +02:00
|
|
|
})
|
2020-09-19 20:49:33 +02:00
|
|
|
];
|
2020-02-11 12:58:16 +01:00
|
|
|
}
|
2020-07-26 16:39:51 +02:00
|
|
|
|
2020-09-19 20:49:33 +02:00
|
|
|
saveWord (wordvalue, replacevalue, fileselection, aliasConfigs = configs) {
|
|
|
|
if (!wordvalue || !replacevalue || !fileselection) return;
|
|
|
|
let filedata = null;
|
|
|
|
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
|
|
|
|
});
|
|
|
|
}
|
|
|
|
aliases[wordvalue] = {
|
|
|
|
replace: replacevalue,
|
|
|
|
filedata: filedata,
|
|
|
|
case: aliasConfigs.case,
|
|
|
|
exact: wordvalue.indexOf(" ") > -1 ? false : aliasConfigs.exact,
|
|
|
|
autoc: aliasConfigs.regex ? false : aliasConfigs.autoc,
|
|
|
|
regex: aliasConfigs.regex,
|
|
|
|
file: filedata != null
|
|
|
|
};
|
|
|
|
BDFDB.DataUtils.save(aliases, this, "words");
|
|
|
|
}
|
|
|
|
};
|
2020-10-09 21:09:35 +02:00
|
|
|
})(window.BDFDB_Global.PluginUtils.buildPlugin(config));
|
2020-09-19 20:49:33 +02:00
|
|
|
})();
|