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" ; }
2019-01-10 11:09:05 +01:00
2020-06-28 11:29:25 +02:00
getVersion ( ) { return "2.1.8" ; }
2019-01-10 11:09:05 +01:00
2020-02-11 12:58:16 +01:00
getAuthor ( ) { return "DevilBro" ; }
2019-01-10 11:09:05 +01:00
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 ;