2020-10-20 23:25:34 +02:00
/ * *
* @ name ChatAliases
2021-03-05 13:26:41 +01:00
* @ author DevilBro
2020-10-20 23:25:34 +02:00
* @ authorId 278543574059057154
2021-05-03 19:59:24 +02:00
* @ version 2.2 . 8
2021-03-05 13:26:41 +01:00
* @ description Allows you to configure your own Aliases / Commands
2020-10-20 23:25:34 +02:00
* @ invite Jx3TjNS
2020-11-19 16:45:36 +01:00
* @ donate https : //www.paypal.me/MircoWittrien
* @ patreon https : //www.patreon.com/MircoWittrien
2021-03-09 15:10:55 +01:00
* @ website https : //mwittrien.github.io/
* @ source https : //github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ChatAliases/
2021-03-10 09:17:37 +01:00
* @ updateUrl https : //mwittrien.github.io/BetterDiscordAddons/Plugins/ChatAliases/ChatAliases.plugin.js
2020-10-20 23:25:34 +02:00
* /
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" ,
2021-05-03 19:59:24 +02:00
"version" : "2.2.8" ,
2021-03-04 11:31:05 +01:00
"description" : "Allows you to configure your own Aliases/Commands"
2020-09-26 18:18:52 +02:00
} ,
"changeLog" : {
2021-04-17 19:27:04 +02:00
"fixed" : {
2021-05-03 19:59:24 +02:00
"Crash Tenor/Giphy" : "Fixed an Issue that caused Discord to crash when clciking a gif with /tenor or /giphy"
2020-09-26 18:18:52 +02:00
}
2020-02-11 12:58:16 +01:00
}
2020-09-19 20:49:33 +02:00
} ;
2020-11-13 19:47:44 +01:00
2020-10-09 21:09:35 +02:00
return ! window . BDFDB _Global || ( ! window . BDFDB _Global . loaded && ! window . BDFDB _Global . started ) ? class {
2021-01-06 12:38:36 +01:00
getName ( ) { return config . info . name ; }
getAuthor ( ) { return config . info . author ; }
getVersion ( ) { return config . info . version ; }
2021-02-01 17:13:13 +01:00
getDescription ( ) { return ` The Library Plugin needed for ${ config . info . name } is missing. Open the Plugin Settings to download it. \n \n ${ config . info . description } ` ; }
downloadLibrary ( ) {
require ( "request" ) . get ( "https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js" , ( e , r , b ) => {
2021-03-05 13:14:18 +01:00
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" } ) ) ;
2021-03-06 14:59:48 +01:00
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" ) ;
2021-02-01 17:13:13 +01:00
} ) ;
}
2020-09-19 20:49:33 +02:00
2021-01-06 12:38:36 +01:00
load ( ) {
2020-11-19 16:51:14 +01:00
if ( ! window . BDFDB _Global || ! Array . isArray ( window . BDFDB _Global . pluginQueue ) ) window . BDFDB _Global = Object . assign ( { } , window . BDFDB _Global , { pluginQueue : [ ] } ) ;
2020-09-19 20:49:33 +02:00
if ( ! window . BDFDB _Global . downloadModal ) {
window . BDFDB _Global . downloadModal = true ;
2021-01-14 16:14:44 +01:00
BdApi . showConfirmationModal ( "Library Missing" , ` The Library Plugin needed for ${ config . info . name } is missing. Please click "Download Now" to install it. ` , {
2020-09-19 20:49:33 +02:00
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 ;
2021-02-01 17:13:13 +01:00
this . downloadLibrary ( ) ;
2020-09-20 08:15:13 +02:00
}
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
}
2021-01-06 12:38:36 +01:00
start ( ) { this . load ( ) ; }
stop ( ) { }
getSettingsPanel ( ) {
2020-11-28 23:12:09 +01:00
let template = document . createElement ( "template" ) ;
2021-01-14 16:14:44 +01:00
template . innerHTML = ` <div style="color: var(--header-primary); font-size: 16px; font-weight: 300; white-space: pre; line-height: 22px;">The Library Plugin needed for ${ config . info . name } is missing. \n Please click <a style="font-weight: 500;">Download Now</a> to install it.</div> ` ;
2021-02-01 17:13:13 +01:00
template . content . firstElementChild . querySelector ( "a" ) . addEventListener ( "click" , this . downloadLibrary ) ;
2020-11-28 23:12:09 +01:00
return template . content . firstElementChild ;
}
2020-10-09 21:09:35 +02:00
} : ( ( [ Plugin , BDFDB ] ) => {
2021-05-03 19:59:24 +02:00
var aliases = { } , commandAliases = { } , commandSentinel ;
2020-09-19 20:49:33 +02:00
2020-10-09 21:09:35 +02:00
return class ChatAliases extends Plugin {
2021-01-06 12:38:36 +01:00
onLoad ( ) {
2020-09-19 20:49:33 +02:00
this . defaults = {
configs : {
2021-01-26 21:40:18 +01:00
case : { value : false , description : "Handle the Word Value case sensitive" } ,
exact : { value : true , description : "Handle the Word Value 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 Word Value as a RegExp String" } ,
file : { value : false , description : "Handle the Replacement Value as a File Path" }
2020-02-11 12:58:16 +01:00
} ,
2021-05-03 19:59:24 +02:00
general : {
2021-01-26 21:40:18 +01: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 Context Menu Entry to faster add new Aliases" } ,
2021-05-03 19:59:24 +02:00
addAutoComplete : { value : true , inner : false , description : "Add an Autocomplete Menu for non-RegExp Aliases" }
} ,
places : {
normal : { value : true , inner : true , description : "Normal Message Textarea" } ,
edit : { value : true , inner : true , description : "Edit Message Textarea" } ,
upload : { 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 : {
2021-01-26 21:40:18 +01:00
minAliasLength : { value : 2 , min : 1 , description : "Minimal Character Length to open Autocomplete Menu: " }
2020-09-19 20:49:33 +02:00
}
} ;
this . patchedModules = {
before : {
ChannelTextAreaForm : "render" ,
MessageEditor : "render" ,
Upload : "render"
2021-04-12 14:12:54 +02:00
} ,
after : {
Autocomplete : "render"
2020-09-19 20:49:33 +02:00
}
} ;
this . css = `
2021-04-12 14:12:54 +02:00
$ { BDFDB . dotCNS . aliasautocomplete + BDFDB . dotCN . autocompleteinner } {
max - height : 50 vh ;
}
2020-09-19 20:49:33 +02:00
$ { BDFDB . dotCN . autocompleteicon } {
flex : 0 0 auto ;
}
` ;
2020-02-11 12:58:16 +01:00
}
2020-09-19 20:49:33 +02:00
2021-01-06 12:38:36 +01:00
onStart ( ) {
2020-06-08 20:07:08 +02:00
aliases = BDFDB . DataUtils . load ( this , "words" ) ;
2020-12-11 17:26:39 +01:00
commandSentinel = BDFDB . LibraryModules . AutocompleteSentinels && BDFDB . LibraryModules . AutocompleteSentinels . COMMAND _SENTINEL || "/" ;
commandAliases = BDFDB . ObjectUtils . filter ( aliases , key => key . startsWith ( commandSentinel ) , true ) ;
2020-09-26 18:18:52 +02:00
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 ) ;
} ,
2020-12-11 17:26:39 +01:00
getSentinel : _ => {
2020-09-26 18:18:52 +02:00
return "" ;
} ,
matches : ( channel , what , wordLowercase , what2 , config , rawValue ) => {
let currentLastWord = BDFDB . StringUtils . findMatchCaseless ( wordLowercase , rawValue , true ) ;
2021-05-03 19:59:24 +02:00
if ( currentLastWord . length >= this . settings . amounts . minAliasLength ) for ( let word in aliases ) {
2020-09-26 18:18:52 +02:00
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 ) => {
2021-01-08 21:25:40 +01:00
if ( rawValue == commandSentinel ) return ;
2020-09-26 18:18:52 +02:00
let currentLastWord = BDFDB . StringUtils . findMatchCaseless ( wordLowercase , rawValue , true ) ;
let matches = [ ] ;
for ( let word in aliases ) {
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 } ;
} ,
2020-12-11 17:26:39 +01:00
renderResults : ( channel , wordLowercase , currentSelected , setSelected , chooseSelected , state , config , autocompletes ) => {
return autocompletes && autocompletes . aliases && [
2020-09-26 18:18:52 +02:00
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . AutocompleteItems . Title , {
title : [
2020-12-11 17:26:39 +01:00
"Aliases: " ,
2020-09-26 18:18:52 +02:00
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 ,
2020-12-11 17:26:39 +01:00
description : BDFDB . StringUtils . insertNRST ( aliasData . replace )
2020-09-26 18:18:52 +02:00
} ) )
] . flat ( 10 ) . filter ( n => n ) ;
}
} ;
2020-12-11 17:26:39 +01:00
BDFDB . PatchUtils . patch ( this , BDFDB . LibraryModules . AutocompleteOptions . AUTOCOMPLETE _OPTIONS . COMMANDS , "renderResults" , { before : e => {
let m = Array . from ( e . methodArguments ) . find ( n => n && n . commands ) ;
if ( m ) {
let currentLastWord = commandSentinel + e . methodArguments [ 1 ] ;
2021-05-03 19:59:24 +02:00
if ( currentLastWord . length >= this . settings . amounts . minAliasLength ) for ( let word in commandAliases ) {
2020-12-11 17:26:39 +01:00
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 ) m . commands . push ( command ) ;
else if ( ! aliasData . case && word . toLowerCase ( ) . indexOf ( currentLastWord . toLowerCase ( ) ) == 0 ) m . commands . push ( command ) ;
}
else {
if ( aliasData . case && word . indexOf ( currentLastWord ) > - 1 ) m . commands . push ( command ) ;
else if ( ! aliasData . case && word . toLowerCase ( ) . indexOf ( currentLastWord . toLowerCase ( ) ) > - 1 ) m . commands . push ( command ) ;
}
2020-09-26 18:18:52 +02:00
}
}
}
} } ) ;
}
2019-01-26 22:45:19 +01:00
2021-05-03 19:59:24 +02:00
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
2020-02-11 12:58:16 +01:00
}
2020-09-19 20:49:33 +02:00
2021-01-06 12:38:36 +01: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 ;
}
2021-05-03 19:59:24 +02:00
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
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 = { } ) {
2020-11-23 20:56:13 +01:00
let settingsPanel ;
return settingsPanel = BDFDB . PluginUtils . createSettingsPanel ( this , {
2020-09-19 20:49:33 +02:00
collapseStates : collapseStates ,
2020-11-23 20:56:13 +01:00
children : _ => {
let settingsItems = [ ] ;
settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . CollapseContainer , {
title : "Settings" ,
collapseStates : collapseStates ,
2021-05-03 19:59:24 +02:00
children : Object . keys ( this . defaults . general ) . map ( key => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
2020-11-23 20:56:13 +01:00
type : "Switch" ,
plugin : this ,
2021-05-03 19:59:24 +02:00
keys : [ "general" , key ] ,
label : this . defaults . general [ key ] . description ,
value : this . settings . general [ key ]
} ) ) . concat ( Object . keys ( this . defaults . amounts ) . map ( key => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
2020-11-23 20:56:13 +01:00
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 ,
2021-05-03 19:59:24 +02:00
value : this . settings . amounts [ key ]
2020-12-15 10:35:30 +01:00
} ) ) ) . concat ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsPanelList , {
2021-01-26 21:40:18 +01:00
title : "Automatically replace Aliases in:" ,
2021-05-03 19:59:24 +02:00
children : Object . keys ( this . settings . places ) . map ( key => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
2020-11-23 20:56:13 +01:00
type : "Switch" ,
plugin : this ,
2021-05-03 19:59:24 +02:00
keys : [ "places" , key ] ,
label : this . defaults . places [ key ] . description ,
value : this . settings . places [ key ]
2020-11-23 20:56:13 +01:00
} ) )
} ) )
} ) ) ;
2021-01-26 21:40:18 +01:00
let values = { wordValue : "" , replaceValue : "" } ;
2020-11-23 20:56:13 +01:00
settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . CollapseContainer , {
2021-01-26 21:40:18 +01:00
title : "Add new Alias" ,
2020-11-23 20:56:13 +01:00
collapseStates : collapseStates ,
2020-09-19 20:49:33 +02:00
children : [
2020-11-23 20:56:13 +01:00
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsItem , {
type : "Button" ,
2021-01-26 21:40:18 +01:00
label : "Pick a Word Value and Replacement Value:" ,
2021-01-29 20:57:25 +01:00
disabled : ! Object . keys ( values ) . every ( valueName => values [ valueName ] ) ,
2020-11-23 20:56:13 +01:00
children : BDFDB . LanguageUtils . LanguageStrings . ADD ,
2021-01-29 20:57:25 +01:00
ref : instance => { if ( instance ) values . addButton = instance ; } ,
2020-11-23 20:56:13 +01:00
onClick : _ => {
2021-01-29 20:57:25 +01:00
this . saveWord ( values ) ;
2020-11-23 20:56:13 +01:00
BDFDB . PluginUtils . refreshSettingsPanel ( this , settingsPanel , collapseStates ) ;
2020-09-19 20:49:33 +02:00
}
} ) ,
2020-11-23 20:56:13 +01:00
this . createInputs ( values )
] . flat ( 10 ) . filter ( n => n )
} ) ) ;
if ( ! BDFDB . ObjectUtils . isEmpty ( aliases ) ) settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . CollapseContainer , {
2021-01-26 21:40:18 +01:00
title : "Added Aliases" ,
2020-11-23 20:56:13 +01:00
collapseStates : collapseStates ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsList , {
settings : Object . keys ( this . defaults . configs ) ,
2021-01-26 21:40:18 +01:00
data : Object . keys ( aliases ) . map ( ( wordValue , i ) => Object . assign ( { } , aliases [ wordValue ] , {
key : wordValue ,
label : wordValue
2020-11-23 20:56:13 +01:00
} ) ) ,
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" ,
color : BDFDB . LibraryComponents . Button . Colors . RED ,
2021-01-26 21:40:18 +01:00
label : "Remove all added Aliases" ,
2020-11-23 20:56:13 +01:00
onClick : _ => {
2021-01-26 21:40:18 +01:00
BDFDB . ModalUtils . confirm ( this , "Are you sure you want to remove all added Aliases?" , _ => {
2020-11-23 20:56:13 +01:00
aliases = { } ;
commandAliases = { } ;
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 : [
2021-01-26 21:40:18 +01:00
"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 Replacement Value. apple to pear => applepie stays applepie" ,
"Not Exact: Will replace Words anywhere they appear. apple to pear => applepieapple to pearpiepear" ,
2020-11-23 20:56:13 +01:00
"Autoc: Will appear in the Autocomplete Menu (if enabled)" ,
[
2021-01-26 21:40:18 +01:00
"Regex: Will treat the entered Word Value as a Regular Expression - " ,
2020-11-23 20:56:13 +01:00
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Anchor , { href : "https://regexr.com/" , children : BDFDB . LanguageUtils . LanguageStrings . HELP + "?" } )
] ,
2021-01-26 21:40:18 +01:00
"File: If the Replacement Value is a File Path it will try to upload the File located at the File Path"
2020-11-23 20:56:13 +01:00
] . map ( string => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormText , {
type : BDFDB . LibraryComponents . FormComponents . FormTextTypes . DESCRIPTION ,
children : string
} ) )
} ) ) ;
return settingsItems ;
}
} ) ;
2020-09-19 20:49:33 +02:00
}
2018-10-11 10:21:26 +02:00
2021-01-06 12:38:36 +01:00
onSettingsClosed ( ) {
2020-09-19 20:49:33 +02:00
if ( this . SettingsUpdated ) {
delete this . SettingsUpdated ;
2021-05-03 19:59:24 +02:00
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
2020-09-19 20:49:33 +02: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 ( ) ) {
2021-05-03 19:59:24 +02:00
if ( ( e . instance . props . type == "NATIVE_TEXT" || e . instance . props . type == "CHANNEL_TEXT_AREA" ) && this . settings . general . addContextMenu ) this . injectItem ( e , e . instance . props . value . trim ( ) ) ;
2020-09-19 20:49:33 +02:00
}
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 ( ) ;
2021-05-03 19:59:24 +02:00
if ( text && this . settings . general . addContextMenu ) this . injectItem ( e , text ) ;
2020-09-19 20:49:33 +02:00
}
2020-01-15 10:45:35 +01:00
2020-09-19 20:49:33 +02:00
onMessageContextMenu ( e ) {
let text = document . getSelection ( ) . toString ( ) . trim ( ) ;
2021-05-03 19:59:24 +02:00
if ( text && this . settings . general . addContextMenu ) this . injectItem ( e , text ) ;
2020-09-19 20:49:33 +02:00
}
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 , {
2020-12-22 20:55:39 +01:00
label : BDFDB . LanguageUtils . LibraryStringsFormat ( "add_to" , "ChatAliases" ) ,
2020-09-19 20:49:33 +02:00
id : BDFDB . ContextMenuUtils . createItemId ( this . name , "add-alias" ) ,
action : _ => {
this . openAddModal ( text . replace ( /\n/g , "\\n" ) . replace ( /\r/g , "\\r" ) . replace ( /\t/g , "\\t" ) ) ;
}
} )
} ) ) ;
}
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 => {
2021-05-03 19:59:24 +02:00
if ( this . settings . places . normal ) this . handleSubmit ( e , e2 , 0 ) ;
2020-09-19 20:49:33 +02:00
} } , { 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 => {
2021-05-03 19:59:24 +02:00
if ( this . settings . places . edit ) this . handleSubmit ( e , e2 , 0 ) ;
2020-09-19 20:49:33 +02:00
} } , { 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 => {
2021-05-03 19:59:24 +02:00
if ( this . settings . places . upload ) this . handleSubmit ( e , e2 , 1 ) ;
2020-09-19 20:49:33 +02:00
} } , { force : true , noCache : true } ) ;
2020-02-11 12:58:16 +01:00
}
2020-09-19 20:49:33 +02:00
2021-04-12 14:12:54 +02:00
processAutocomplete ( e ) {
if ( e . returnvalue . props . children && e . instance . props . className && e . instance . props . className . indexOf ( BDFDB . disCN . aliasautocomplete ) > - 1 ) {
let [ children , index ] = BDFDB . ReactUtils . findParent ( e . returnvalue , { props : [ [ "className" , BDFDB . disCN . autocompleteinner ] ] } ) ;
if ( index > - 1 ) children [ index ] = BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . Scrollers . Thin , children [ index ] . props ) ;
}
}
2020-09-19 20:49:33 +02:00
handleSubmit ( e , e2 , textIndex ) {
2021-05-03 19:59:24 +02:00
if ( ! this . settings . general . replaceBeforeSend || BDFDB . LibraryModules . SlowmodeUtils . getSlowmodeCooldownGuess ( e . instance . props . channel . id ) > 0 ) return ;
2020-09-19 20:49:33 +02:00
let messageData = this . formatText ( e2 . methodArguments [ textIndex ] ) ;
if ( messageData ) {
2021-05-03 19:59:24 +02:00
if ( messageData . text != null && e2 . methodArguments [ textIndex ] != messageData . text ) {
2020-09-19 20:49:33 +02:00
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" ) ) ) {
2020-12-17 20:05:26 +01:00
let reply = BDFDB . LibraryModules . MessageReplyStore . getPendingReply ( e . instance . props . channel . id ) ;
if ( reply && ! messageData . text ) BDFDB . LibraryModules . UploadUtils . upload ( e . instance . props . channel . id , messageData . files . shift ( ) , "" , false ) ;
2020-09-19 20:49:33 +02:00
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 ) ;
2020-11-19 16:51:14 +01:00
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 ) ;
2020-11-19 16:51:14 +01:00
files . push ( new File ( [ Uint8Array . from ( atob ( filedata . data ) , c => c . charCodeAt ( 0 ) ) ] , filedata . name , { type : filedata . type } ) ) ;
2020-09-19 20:49:33 +02:00
}
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 ;
}
2021-01-26 21:40:18 +01:00
openAddModal ( wordValue ) {
2021-01-29 20:57:25 +01:00
let values = { wordValue , replaceValue : "" } ;
let configs = BDFDB . ObjectUtils . map ( BDFDB . ObjectUtils . filter ( this . defaults . configs , key => key != "file" , true ) , n => n . value ) ;
2020-09-19 20:49:33 +02:00
BDFDB . ModalUtils . open ( this , {
size : "MEDIUM" ,
2020-12-22 20:55:39 +01:00
header : BDFDB . LanguageUtils . LibraryStringsFormat ( "add_to" , "ChatAliases" ) ,
2021-01-23 18:50:24 +01:00
subHeader : "" ,
2020-09-19 20:49:33 +02:00
children : [
this . createInputs ( values ) ,
2021-01-29 20:57:25 +01:00
Object . keys ( configs ) . map ( key => BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsItem , {
2020-09-19 20:49:33 +02:00
type : "Switch" ,
label : this . defaults . configs [ key ] . description ,
2021-01-29 20:57:25 +01:00
value : configs [ key ] ,
onChange : value => { configs [ key ] = value ; }
2020-09-19 20:49:33 +02:00
} ) )
] . flat ( 10 ) . filter ( n => n ) ,
buttons : [ {
2021-01-29 20:57:25 +01:00
disabled : ! Object . keys ( values ) . every ( valueName => values [ valueName ] ) ,
2020-09-19 20:49:33 +02:00
contents : BDFDB . LanguageUtils . LanguageStrings . ADD ,
color : "BRAND" ,
close : true ,
2021-01-29 20:57:25 +01:00
ref : instance => { if ( instance ) values . addButton = instance ; } ,
onClick : _ => {
this . saveWord ( values , configs ) ;
2021-05-03 19:59:24 +02:00
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
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 , {
2020-11-19 16:45:36 +01:00
title : "Replace:" ,
2021-01-13 18:54:21 +01:00
className : BDFDB . disCN . marginbottom8 ,
2020-09-19 20:49:33 +02:00
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TextInput , {
2021-01-26 21:40:18 +01:00
value : values . wordValue ,
placeholder : values . wordValue ,
errorMessage : ! values . wordValue && "Choose a Word Value" || aliases [ values . wordValue ] && "Word Value already used, saving will overwrite old Alias" ,
2020-09-19 20:49:33 +02:00
onChange : ( value , instance ) => {
2021-01-26 21:40:18 +01:00
values . wordValue = value . trim ( ) ;
if ( ! values . wordValue ) instance . props . errorMessage = "Choose a Word Value" ;
else if ( aliases [ values . wordValue ] ) instance . props . errorMessage = "Word Value already used, saving will overwrite old Alias" ;
2020-09-19 20:49:33 +02:00
else delete instance . props . errorMessage ;
2021-01-29 20:57:25 +01:00
values . addButton . props . disabled = ! Object . keys ( values ) . every ( valueName => values [ valueName ] ) ;
BDFDB . ReactUtils . forceUpdate ( values . addButton ) ;
2020-07-02 10:42:56 +02:00
}
2020-09-19 20:49:33 +02:00
} )
} ) ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . FormComponents . FormItem , {
2020-11-19 16:45:36 +01:00
title : "With:" ,
2021-01-13 18:54:21 +01:00
className : BDFDB . disCN . marginbottom8 ,
2020-09-19 20:49:33 +02:00
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TextInput , {
type : "file" ,
useFilePath : true ,
2021-01-26 21:40:18 +01:00
value : values . replaceValue ,
placeholder : values . replaceValue ,
2020-09-19 20:49:33 +02:00
autoFocus : true ,
2021-01-26 21:40:18 +01:00
errorMessage : ! values . replaceValue && "Choose a Replacement Value" ,
2021-04-17 19:27:04 +02:00
controlsRef : instance => { if ( instance ) values . fileSelection = BDFDB . ReactUtils . findDOMNode ( instance ) . querySelector ( "input" ) ; } ,
2020-09-19 20:49:33 +02:00
onChange : ( value , instance ) => {
2021-01-26 21:40:18 +01:00
values . replaceValue = value . trim ( ) ;
if ( ! values . replaceValue ) instance . props . errorMessage = "Choose a Replacement Value" ;
2020-09-19 20:49:33 +02:00
else delete instance . props . errorMessage ;
2021-01-29 20:57:25 +01:00
values . addButton . props . disabled = ! Object . keys ( values ) . every ( valueName => values [ valueName ] ) ;
BDFDB . ReactUtils . forceUpdate ( values . addButton ) ;
2020-09-19 20:49:33 +02:00
}
} )
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
2021-05-03 19:59:24 +02:00
saveWord ( values , aliasConfigs = this . settings . configs ) {
2021-01-29 20:57:25 +01:00
if ( ! values . wordValue || ! values . replaceValue || ! values . fileSelection ) return ;
2021-04-17 19:27:04 +02:00
let fileData = null ;
2021-01-29 20:57:25 +01:00
if ( values . fileSelection . files && values . fileSelection . files [ 0 ] && BDFDB . LibraryRequires . fs . existsSync ( values . replaceValue ) ) {
2021-04-17 19:27:04 +02:00
fileData = JSON . stringify ( {
2021-01-29 20:57:25 +01:00
data : BDFDB . LibraryRequires . fs . readFileSync ( values . replaceValue ) . toString ( "base64" ) ,
name : values . fileSelection . files [ 0 ] . name ,
type : values . fileSelection . files [ 0 ] . type
2020-09-19 20:49:33 +02:00
} ) ;
}
2021-01-29 20:57:25 +01:00
aliases [ values . wordValue ] = {
replace : values . replaceValue ,
2021-04-17 19:27:04 +02:00
filedata : fileData ,
2020-09-19 20:49:33 +02:00
case : aliasConfigs . case ,
2021-01-29 20:57:25 +01:00
exact : values . wordValue . indexOf ( " " ) > - 1 ? false : aliasConfigs . exact ,
2020-09-19 20:49:33 +02:00
autoc : aliasConfigs . regex ? false : aliasConfigs . autoc ,
regex : aliasConfigs . regex ,
2021-04-17 19:27:04 +02:00
file : fileData != null
2020-09-19 20:49:33 +02:00
} ;
BDFDB . DataUtils . save ( aliases , this , "words" ) ;
}
} ;
2020-10-09 21:09:35 +02:00
} ) ( window . BDFDB _Global . PluginUtils . buildPlugin ( config ) ) ;
2021-04-13 07:16:28 +02:00
} ) ( ) ;