2019-09-20 22:32:52 +02:00
//META{"name":"SendLargeMessages","website":"https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/SendLargeMessages","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/SendLargeMessages/SendLargeMessages.plugin.js"}*//
2018-10-11 10:21:26 +02:00
class SendLargeMessages {
2019-01-17 23:48:29 +01:00
getName ( ) { return "SendLargeMessages" ; }
2020-01-08 09:54:19 +01:00
getVersion ( ) { return "1.6.3" ; }
2019-01-17 23:48:29 +01:00
getAuthor ( ) { return "DevilBro" ; }
getDescription ( ) { return "Opens a popout when your message is too large, which allows you to automatically send the message in several smaller messages." ; }
2019-01-26 22:45:19 +01:00
2019-09-04 12:34:02 +02:00
constructor ( ) {
2019-02-28 20:09:44 +01:00
this . changelog = {
2020-01-07 23:12:47 +01:00
"fixed" : [ [ "New WYSIWYG Textarea" , "Fixed for the new WYSIWYG Textarea that is hidden by experiments" ] ]
2019-02-28 20:09:44 +01:00
} ;
2019-09-04 12:34:02 +02:00
2019-11-14 17:56:26 +01:00
this . patchedModules = {
2019-12-17 14:51:58 +01:00
before : {
2019-12-21 11:25:13 +01:00
ChannelTextAreaForm : "render" ,
ChannelEditorContainer : "render"
2019-12-28 17:39:14 +01:00
} ,
after : {
ChannelTextAreaContainer : "render" ,
2019-11-14 17:56:26 +01:00
}
2018-12-27 08:57:16 +01:00
} ;
2019-09-04 12:34:02 +02:00
}
2019-01-26 22:45:19 +01:00
2019-09-04 12:34:02 +02:00
initConstructor ( ) {
2018-10-11 10:21:26 +02:00
this . messageDelay = 1000 ; //changing at own risk, might result in bans or mutes
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
this . css = `
2019-01-24 13:37:08 +01:00
. $ { this . name } - modal textarea {
2019-11-11 11:11:33 +01:00
height : 50 vh ;
2018-10-11 10:21:26 +02:00
} ` ;
}
//legacy
load ( ) { }
start ( ) {
2020-01-17 19:50:31 +01:00
if ( ! window . BDFDB ) window . BDFDB = { myPlugins : { } } ;
if ( window . BDFDB && window . BDFDB . myPlugins && typeof window . BDFDB . myPlugins == "object" ) window . BDFDB . myPlugins [ this . getName ( ) ] = this ;
2020-01-21 12:56:26 +01:00
let libraryScript = document . querySelector ( "head script#BDFDBLibraryScript" ) ;
2019-05-26 13:55:26 +02:00
if ( ! libraryScript || ( performance . now ( ) - libraryScript . getAttribute ( "date" ) ) > 600000 ) {
2018-10-11 10:21:26 +02:00
if ( libraryScript ) libraryScript . remove ( ) ;
libraryScript = document . createElement ( "script" ) ;
2019-05-26 13:55:26 +02:00
libraryScript . setAttribute ( "id" , "BDFDBLibraryScript" ) ;
2018-10-11 10:21:26 +02:00
libraryScript . setAttribute ( "type" , "text/javascript" ) ;
2019-10-18 10:56:41 +02:00
libraryScript . setAttribute ( "src" , "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js" ) ;
2019-01-17 23:48:29 +01:00
libraryScript . setAttribute ( "date" , performance . now ( ) ) ;
2020-01-14 00:06:07 +01:00
libraryScript . addEventListener ( "load" , _ => { this . initialize ( ) ; } ) ;
2018-10-11 10:21:26 +02:00
document . head . appendChild ( libraryScript ) ;
2019-05-26 13:55:26 +02:00
}
2020-01-17 19:50:31 +01:00
else if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) this . initialize ( ) ;
2020-01-14 00:06:07 +01:00
this . startTimeout = setTimeout ( _ => {
2019-11-01 10:27:07 +01:00
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 ) ;
2018-10-11 10:21:26 +02:00
}
initialize ( ) {
2020-01-17 19:50:31 +01:00
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
2019-01-22 11:05:54 +01:00
if ( this . started ) return ;
2019-10-22 18:55:25 +02:00
BDFDB . PluginUtils . init ( this ) ;
2019-11-11 11:11:33 +01:00
2019-10-22 18:55:25 +02:00
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
2018-10-11 10:21:26 +02:00
}
2019-11-01 10:14:50 +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
}
stop ( ) {
2020-01-17 19:50:31 +01:00
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
2019-10-22 11:37:23 +02:00
this . stopping = true ;
2019-11-11 11:11:33 +01:00
BDFDB . ModuleUtils . forceAllUpdates ( this ) ;
2019-10-22 18:55:25 +02:00
BDFDB . PluginUtils . clear ( this ) ;
2018-10-11 10:21:26 +02:00
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
// begin of own functions
2019-12-21 11:25:13 +01:00
processChannelTextAreaForm ( e ) {
if ( ! BDFDB . ModuleUtils . isPatched ( this , e . instance , "handleSendMessage" ) ) BDFDB . ModuleUtils . patch ( this , e . instance , "handleSendMessage" , { instead : e2 => {
2020-01-08 09:54:19 +01:00
if ( e2 . methodArguments [ 0 ] . length > BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH ) {
2019-12-21 11:25:13 +01:00
e2 . stopOriginalMethodCall ( ) ;
2020-01-07 23:12:47 +01:00
let messages = this . formatText ( e2 . methodArguments [ 0 ] ) ;
2019-12-21 11:25:13 +01:00
messages . filter ( n => n ) . forEach ( ( message , i ) => {
BDFDB . TimeUtils . timeout ( _ => {
e2 . originalMethod ( message ) ;
if ( i >= messages . length - 1 ) BDFDB . NotificationUtils . toast ( this . labels . toast _allsent _text , { type : "success" } ) ;
} , this . messageDelay * i ) ;
} ) ;
return Promise . resolve ( {
shouldClear : true ,
shouldRefocus : true
} ) ;
}
else return e2 . callOriginalMethodAfterwards ( ) ;
} } , true ) ;
}
2019-12-28 17:39:14 +01:00
processChannelTextAreaContainer ( e ) {
if ( e . returnvalue . ref && e . returnvalue . ref . current && BDFDB . DOMUtils . getParent ( BDFDB . dotCN . chatform , e . returnvalue . ref . current ) ) {
let [ children , index ] = BDFDB . ReactUtils . findChildren ( e . returnvalue , { name : "SlateCharacterCount" } ) ;
if ( index > - 1 ) {
2020-01-07 23:12:47 +01:00
let text = BDFDB . LibraryModules . SlateSelectionUtils . serialize ( children [ index ] . props . document , "raw" ) ;
if ( text . length > BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH ) children [ index ] = BDFDB . ReactUtils . createElement ( "div" , {
className : BDFDB . disCNS . textareacharcounter + BDFDB . disCN . textareacharcountererror ,
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TooltipContainer , {
text : Math . ceil ( text . length / BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH * ( 39 / 40 ) ) + " " + BDFDB . LanguageUtils . LanguageStrings . MESSAGES ,
children : BDFDB . ReactUtils . createElement ( "span" , {
children : BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH - text . length
2019-12-28 17:39:14 +01:00
} )
2020-01-07 23:12:47 +01:00
} )
} ) ;
2019-12-28 17:39:14 +01:00
}
}
2019-12-28 19:13:02 +01:00
}
2019-12-21 11:25:13 +01:00
processChannelEditorContainer ( e ) {
if ( e . instance . props . type && e . instance . props . type == BDFDB . DiscordConstants . TextareaTypes . NORMAL ) e . instance . props . shouldUploadLongMessages = false ;
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-01-07 23:12:47 +01:00
formatText ( text ) {
2019-06-20 10:07:17 +02:00
text = text . replace ( /\t/g , " " ) ;
2018-12-27 08:57:16 +01:00
let longwords = text . match ( /[\S]{1800,}/gm ) ;
2019-12-17 14:51:58 +01:00
if ( longwords ) for ( let longword of longwords ) {
2018-10-11 10:21:26 +02:00
let count1 = 0 ;
let shortwords = [ ] ;
2019-12-17 14:51:58 +01:00
longword . split ( "" ) . forEach ( c => {
2020-01-07 23:12:47 +01:00
if ( shortwords [ count1 ] && shortwords [ count1 ] . length >= BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH * ( 19 / 20 ) ) count1 ++ ;
2019-12-17 14:51:58 +01:00
shortwords [ count1 ] = shortwords [ count1 ] ? shortwords [ count1 ] + c : c ;
2018-10-11 10:21:26 +02:00
} ) ;
text = text . replace ( longword , shortwords . join ( " " ) ) ;
}
2018-12-27 08:57:16 +01:00
let messages = [ ] ;
let count2 = 0 ;
2018-10-11 10:21:26 +02:00
text . split ( " " ) . forEach ( ( word ) => {
2020-01-07 23:12:47 +01:00
if ( messages [ count2 ] && ( messages [ count2 ] + "" + word ) . length > BDFDB . DiscordConstants . MAX _MESSAGE _LENGTH * ( 39 / 40 ) ) count2 ++ ;
2018-10-11 10:21:26 +02:00
messages [ count2 ] = messages [ count2 ] ? messages [ count2 ] + " " + word : word ;
} ) ;
2019-01-26 22:45:19 +01:00
2018-12-27 08:57:16 +01:00
let insertCodeBlock = null , insertCodeLine = null ;
for ( let j = 0 ; j < messages . length ; j ++ ) {
2018-10-11 10:21:26 +02:00
if ( insertCodeBlock ) {
messages [ j ] = insertCodeBlock + messages [ j ] ;
insertCodeBlock = null ;
}
else if ( insertCodeLine ) {
messages [ j ] = insertCodeLine + messages [ j ] ;
insertCodeLine = null ;
}
2019-01-26 22:45:19 +01:00
2018-12-27 08:57:16 +01:00
let codeBlocks = messages [ j ] . match ( /`{3,}[\S]*\n|`{3,}/gm ) ;
let codeLines = messages [ j ] . match ( /[^`]{0,1}`{1,2}[^`]|[^`]`{1,2}[^`]{0,1}/gm ) ;
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
if ( codeBlocks && codeBlocks . length % 2 == 1 ) {
messages [ j ] = messages [ j ] + "```" ;
insertCodeBlock = codeBlocks [ codeBlocks . length - 1 ] + "\n" ;
}
else if ( codeLines && codeLines . length % 2 == 1 ) {
insertCodeLine = codeLines [ codeLines . length - 1 ] . replace ( /[^`]/g , "" ) ;
messages [ j ] = messages [ j ] + insertCodeLine ;
}
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
return messages ;
}
2019-01-26 22:45:19 +01:00
2018-10-11 10:21:26 +02:00
setLabelsByLanguage ( ) {
2019-10-22 19:38:25 +02:00
switch ( BDFDB . LanguageUtils . getLanguage ( ) . id ) {
2018-10-11 10:21:26 +02:00
case "hr" : //croatian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Sve veliku poslane."
2018-10-11 10:21:26 +02:00
} ;
case "da" : //danish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Alle beskeder sendes."
2018-10-11 10:21:26 +02:00
} ;
case "de" : //german
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Alle Nachrichten versendet."
2018-10-11 10:21:26 +02:00
} ;
case "es" : //spanish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Todos los mensajes enviados."
2018-10-11 10:21:26 +02:00
} ;
case "fr" : //french
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Tous les messages envoyés"
2018-10-11 10:21:26 +02:00
} ;
case "it" : //italian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Tutti i messaggi inviati."
2018-10-11 10:21:26 +02:00
} ;
case "nl" : //dutch
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Alle berichten verzonden."
2018-10-11 10:21:26 +02:00
} ;
case "no" : //norwegian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Alle meldinger sendt."
2018-10-11 10:21:26 +02:00
} ;
case "pl" : //polish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Wszystkie wiadomości zostały wysłane."
2018-10-11 10:21:26 +02:00
} ;
case "pt-BR" : //portuguese (brazil)
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Todas as mensagens enviadas."
2018-10-11 10:21:26 +02:00
} ;
case "fi" : //finnish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Kaikki lähetetyt viestit."
2018-10-11 10:21:26 +02:00
} ;
case "sv" : //swedish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Alla meddelanden skickade."
2018-10-11 10:21:26 +02:00
} ;
case "tr" : //turkish
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Tüm mesajlar gönderildi."
2018-10-11 10:21:26 +02:00
} ;
case "cs" : //czech
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Všechny zprávy byly odeslány."
2018-10-11 10:21:26 +02:00
} ;
case "bg" : //bulgarian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "Всички изпратени съобщения."
2018-10-11 10:21:26 +02:00
} ;
case "ru" : //russian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "В с е отправленные сообщения."
2018-10-11 10:21:26 +02:00
} ;
case "uk" : //ukrainian
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "В с і повідомлення надіслано."
2018-10-11 10:21:26 +02:00
} ;
case "ja" : //japanese
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "すべてのメッセージが送信されました。"
2018-10-11 10:21:26 +02:00
} ;
case "zh-TW" : //chinese (traditional)
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "發送的所有消息。"
2018-10-11 10:21:26 +02:00
} ;
case "ko" : //korean
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "모든 메시지가 전송되었습니다."
2018-10-11 10:21:26 +02:00
} ;
default : //default: english
return {
2019-12-28 17:39:14 +01:00
toast _allsent _text : "All messages sent."
2018-10-11 10:21:26 +02:00
} ;
}
}
}