2020-02-27 08:44:03 +01:00
//META{"name":"ReverseImageSearch","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/ReverseImageSearch","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ReverseImageSearch/ReverseImageSearch.plugin.js"}*//
2018-10-11 10:21:26 +02:00
2020-02-04 22:49:47 +01:00
var ReverseImageSearch = ( _ => {
2020-02-04 22:50:48 +01:00
const imgUrlReplaceString = "DEVILBRO_BD_REVERSEIMAGESEARCH_REPLACE_IMAGEURL" ;
2020-02-04 22:49:47 +01:00
return class ReverseImageSearch {
getName ( ) { return "ReverseImageSearch" ; }
2019-01-17 23:48:29 +01:00
2020-02-13 12:35:32 +01:00
getVersion ( ) { return "3.5.3" ; }
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
getAuthor ( ) { return "DevilBro" ; }
2019-01-17 23:48:29 +01:00
2020-02-04 22:49:47 +01:00
getDescription ( ) { return "Adds a reverse image search option to the context menu." ; }
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
constructor ( ) {
this . changelog = {
2020-02-13 12:35:32 +01:00
"improved" : [ [ "One Engine" , "Enabling only one search engine doesn't create a SubMenu anymore" ] , [ "New Library Structure & React" , "Restructured my Library and switched to React rendering instead of DOM manipulation" ] ]
2020-02-04 22:49:47 +01:00
} ;
}
2019-09-04 12:34:02 +02:00
2020-02-04 22:49:47 +01:00
initConstructor ( ) {
this . defaults = {
settings : {
useChromium : { value : false , inner : false , description : "Use an inbuilt browser window instead of opening your default browser" } ,
addUserAvatarEntry : { value : true , inner : true , description : "User Avatars" } ,
addGuildIconEntry : { value : true , inner : true , description : "Server Icons" } ,
addEmojiEntry : { value : true , inner : true , description : "Custom Emojis/Emotes" }
} ,
engines : {
_all : { value : true , name : BDFDB . LanguageUtils . LanguageStrings . FORM _LABEL _ALL , url : null } ,
2020-02-04 22:50:48 +01:00
Baidu : { value : true , name : "Baidu" , url : "http://image.baidu.com/pcdutu?queryImageUrl=" + imgUrlReplaceString } ,
Bing : { value : true , name : "Bing" , url : "https://www.bing.com/images/search?q=imgurl:" + imgUrlReplaceString + "&view=detailv2&iss=sbi&FORM=IRSBIQ" } ,
Google : { value : true , name : "Google" , url : "https://images.google.com/searchbyimage?image_url=" + imgUrlReplaceString } ,
IQDB : { value : true , name : "IQDB" , url : "https://iqdb.org/?url=" + imgUrlReplaceString } ,
Reddit : { value : true , name : "Reddit" , url : "http://karmadecay.com/search?q=" + imgUrlReplaceString } ,
SauceNAO : { value : true , name : "SauceNAO" , url : "https://saucenao.com/search.php?db=999&url=" + imgUrlReplaceString } ,
Sogou : { value : true , name : "Sogou" , url : "http://pic.sogou.com/ris?flag=1&drag=0&query=" + imgUrlReplaceString + "&flag=1" } ,
TinEye : { value : true , name : "TinEye" , url : "https://tineye.com/search?url=" + imgUrlReplaceString } ,
WhatAnime : { value : true , name : "WhatAnime" , url : "https://trace.moe/?url=" + imgUrlReplaceString } ,
Yandex : { value : true , name : "Yandex" , url : "https://yandex.com/images/search?url=" + imgUrlReplaceString + "&rpt=imageview" }
2020-02-04 22:49:47 +01:00
}
} ;
}
2018-10-11 10:21:26 +02:00
2020-02-04 22:49:47 +01:00
getSettingsPanel ( ) {
if ( ! window . BDFDB || typeof BDFDB != "object" || ! BDFDB . loaded || ! this . started ) return ;
let settings = BDFDB . DataUtils . get ( this , "settings" ) ;
let engines = BDFDB . DataUtils . get ( this , "engines" ) ;
let settingspanel , settingsitems = [ ] , inneritems = [ ] , engineitems = [ ] ;
for ( let key in settings ) ( ! this . defaults . settings [ key ] . inner ? settingsitems : inneritems ) . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
className : BDFDB . disCN . marginbottom8 ,
type : "Switch" ,
plugin : this ,
keys : [ "settings" , key ] ,
label : this . defaults . settings [ key ] . description ,
value : settings [ key ]
} ) ) ;
for ( let key in engines ) engineitems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
className : BDFDB . disCN . marginbottom8 ,
type : "Switch" ,
plugin : this ,
keys : [ "engines" , key ] ,
label : this . defaults . engines [ key ] . name ,
value : engines [ key ]
} ) ) ;
settingsitems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsPanelInner , {
title : "Add extra ContextMenu Entry for:" ,
first : settingsitems . length == 0 ,
last : true ,
children : inneritems
} ) ) ;
settingsitems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsPanelInner , {
title : "Search Engines:" ,
first : settingsitems . length == 0 ,
last : true ,
children : engineitems
} ) ) ;
return settingspanel = BDFDB . PluginUtils . createSettingsPanel ( this , settingsitems ) ;
}
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
//legacy
load ( ) { }
2018-10-11 10:21:26 +02:00
2020-02-04 22:49:47 +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-04 22:49:47 +01:00
initialize ( ) {
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
if ( this . started ) return ;
BDFDB . PluginUtils . init ( this ) ;
}
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-04 22:49:47 +01:00
stop ( ) {
if ( window . BDFDB && typeof BDFDB === "object" && BDFDB . loaded ) {
this . stopping = true ;
2019-10-22 11:37:23 +02:00
2020-02-04 22:49:47 +01:00
BDFDB . PluginUtils . clear ( this ) ;
}
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
// begin of own functions
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
onGuildContextMenu ( e ) {
if ( e . instance . props . guild && e . instance . props . target ) {
let guildicon = BDFDB . DOMUtils . containsClass ( e . instance . props . target , BDFDB . disCN . avataricon ) ? e . instance . props . target : e . instance . props . target . querySelector ( BDFDB . dotCN . guildicon ) ;
if ( guildicon && BDFDB . DataUtils . get ( this , "settings" , "addGuildIconEntry" ) ) this . injectItem ( e , guildicon . tagName == "IMG" ? guildicon . getAttribute ( "src" ) : guildicon . style . getPropertyValue ( "background-image" ) ) ;
}
2019-10-06 16:41:40 +02:00
}
2020-02-04 22:49:47 +01:00
onUserContextMenu ( e ) {
if ( e . instance . props . user && e . instance . props . target ) {
2020-02-04 23:04:29 +01:00
let avatar = e . instance . props . target . querySelector ( BDFDB . dotCN . avatar ) || e . instance . props . target ;
if ( avatar && BDFDB . DataUtils . get ( this , "settings" , "addUserAvatarEntry" ) ) this . injectItem ( e , avatar . tagName == "IMG" ? avatar . getAttribute ( "src" ) : avatar . style . getPropertyValue ( "background-image" ) ) ;
2020-02-04 22:49:47 +01:00
}
2019-10-05 17:46:38 +02:00
}
2020-02-04 22:49:47 +01:00
onNativeContextMenu ( e ) {
if ( e . instance . props . type == BDFDB . DiscordConstants . ContextMenuTypes . NATIVE _IMAGE && ( e . instance . props . href || e . instance . props . src ) ) {
this . injectItem ( e , e . instance . props . href || e . instance . props . src ) ;
}
2019-11-29 19:11:56 +01:00
}
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
onMessageContextMenu ( e ) {
if ( e . instance . props . message && e . instance . props . channel && e . instance . props . target ) {
if ( e . instance . props . attachment ) this . injectItem ( e , e . instance . props . attachment . url ) ;
else if ( e . instance . props . target . tagName == "A" && e . instance . props . message . embeds && e . instance . props . message . embeds [ 0 ] && e . instance . props . message . embeds [ 0 ] . type == "image" ) this . injectItem ( e , e . instance . props . target . href ) ;
else if ( e . instance . props . target . tagName == "IMG" ) {
if ( BDFDB . DOMUtils . containsClass ( e . instance . props . target . parentElement , BDFDB . disCN . imagewrapper ) ) this . injectItem ( e , e . instance . props . target . src ) ;
2020-02-04 23:04:29 +01:00
else if ( BDFDB . DOMUtils . containsClass ( e . instance . props . target , BDFDB . disCN . embedauthoricon ) && BDFDB . DataUtils . get ( this , "settings" , "addUserAvatarEntry" ) ) this . injectItem ( e , e . instance . props . target . src ) ;
2020-02-04 22:49:47 +01:00
else if ( BDFDB . DOMUtils . containsClass ( e . instance . props . target , "emoji" , "emote" , false ) && BDFDB . DataUtils . get ( this , "settings" , "addEmojiEntry" ) ) this . injectItem ( e , e . instance . props . target . src ) ;
}
}
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
injectItem ( e , url ) {
if ( url && url . indexOf ( "discordapp.com/assets/" ) == - 1 && ! url . endsWith ( ".mp4" ) ) {
url = url . replace ( /^url\(|\)$|"|'/g , "" ) . replace ( /\?size\=\d+$/ , "?size=4096" ) ;
if ( url . indexOf ( "https://images-ext-1.discordapp.net/external/" ) > - 1 ) {
if ( url . split ( "/https/" ) . length != 1 ) url = "https://" + url . split ( "/https/" ) [ url . split ( "/https/" ) . length - 1 ] ;
else if ( url . split ( "/http/" ) . length != 1 ) url = "http://" + url . split ( "/http/" ) [ url . split ( "/http/" ) . length - 1 ] ;
2019-09-11 12:14:43 +02:00
}
2020-02-13 12:35:32 +01:00
let enabledEngines = BDFDB . ObjectUtils . filter ( BDFDB . DataUtils . get ( this , "engines" ) , n => n ) ;
let enginesWithoutAll = BDFDB . ObjectUtils . filter ( enabledEngines , n => n != "_all" , true ) ;
let engineKeys = Object . keys ( enginesWithoutAll ) ;
let [ children , index ] = BDFDB . ReactUtils . findChildren ( e . returnvalue , { name : [ "FluxContainer(MessageDeveloperModeGroup)" , "DeveloperModeGroup" ] } ) ;
if ( engineKeys . length == 1 ) children . splice ( index > - 1 ? index : children . length , 0 , BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Item , {
label : this . labels . context _reverseimagesearch _text . replace ( "..." , this . defaults . engines [ engineKeys [ 0 ] ] . name ) ,
2020-02-04 22:49:47 +01:00
action : event => {
let useChromium = BDFDB . DataUtils . get ( this , "settings" , "useChromium" ) ;
if ( ! event . shiftKey ) BDFDB . ContextMenuUtils . close ( e . instance ) ;
2020-02-13 12:35:32 +01:00
BDFDB . DiscordUtils . openLink ( this . defaults . engines [ engineKeys [ 0 ] ] . url . replace ( imgUrlReplaceString , encodeURIComponent ( url ) ) , useChromium , event . shiftKey ) ;
2020-02-04 22:49:47 +01:00
}
} ) ) ;
2020-02-13 12:35:32 +01:00
else {
let items = [ ] ;
for ( let key in enabledEngines ) items . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Item , {
label : this . defaults . engines [ key ] . name ,
danger : key == "_all" ,
action : event => {
let useChromium = BDFDB . DataUtils . get ( this , "settings" , "useChromium" ) ;
if ( ! event . shiftKey ) BDFDB . ContextMenuUtils . close ( e . instance ) ;
if ( key == "_all" ) {
for ( let key2 in enginesWithoutAll ) BDFDB . DiscordUtils . openLink ( this . defaults . engines [ key2 ] . url . replace ( imgUrlReplaceString , encodeURIComponent ( url ) ) , useChromium , event . shiftKey ) ;
}
else BDFDB . DiscordUtils . openLink ( this . defaults . engines [ key ] . url . replace ( imgUrlReplaceString , encodeURIComponent ( url ) ) , useChromium , event . shiftKey ) ;
}
} ) ) ;
if ( ! items . length ) items . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Item , {
label : this . labels . submenu _disabled _text ,
disabled : true
} ) ) ;
children . splice ( index > - 1 ? index : children . length , 0 , BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Group , {
children : BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . ContextMenuItems . Sub , {
label : this . labels . context _reverseimagesearch _text ,
render : items
} )
} ) ) ;
}
2020-02-04 22:49:47 +01:00
}
2018-10-11 10:21:26 +02:00
}
2019-01-26 22:45:19 +01:00
2020-02-04 22:49:47 +01:00
setLabelsByLanguage ( ) {
switch ( BDFDB . LanguageUtils . getLanguage ( ) . id ) {
case "hr" : //croatian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Traži sliku ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Svi su onemogućeni"
} ;
case "da" : //danish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Søg billede med ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Alle deaktiveret"
} ;
case "de" : //german
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Bild suchen mit ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Alle deaktiviert"
} ;
case "es" : //spanish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Buscar imagen con ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Todo desactivado"
} ;
case "fr" : //french
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Rechercher une image avec ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Tous désactivés"
} ;
case "it" : //italian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Cerca immagine con ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Tutto disattivato"
} ;
case "nl" : //dutch
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Afbeelding zoeken met ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Alles gedeactiveerd"
} ;
case "no" : //norwegian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Søk på bilde med ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Alle deaktivert"
} ;
case "pl" : //polish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Wyszukaj obraz za pomocą ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Wszystkie wyłączone"
} ;
case "pt-BR" : //portuguese (brazil)
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Pesquisar imagem com ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Todos desativados"
} ;
case "fi" : //finnish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Hae kuvaa ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Kaikki on poistettu käytöstä"
} ;
case "sv" : //swedish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Sök bild med ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Alla avaktiverade"
} ;
case "tr" : //turkish
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Görüntüyü şununla ara ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Hepsi deaktive"
} ;
case "cs" : //czech
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Vyhledat obrázek pomocí ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Všechny deaktivované"
} ;
case "bg" : //bulgarian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Търсене на изображение с ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "Всички с а деактивирани"
} ;
case "ru" : //russian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Поиск изображения с ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "В с е деактивированные"
} ;
case "uk" : //ukrainian
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Шукати зображення за допомогою ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "В с і вимкнені"
} ;
case "ja" : //japanese
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "で画像を検索 ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "すべて非アクティブ化"
} ;
case "zh-TW" : //chinese (traditional)
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "搜尋圖片 ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "全部停用"
} ;
case "ko" : //korean
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "로 이미지 검색 ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "모두 비활성화 됨"
} ;
default : //default: english
return {
2020-02-13 12:35:32 +01:00
context _reverseimagesearch _text : "Search image with ..." ,
2020-02-04 22:49:47 +01:00
submenu _disabled _text : "All disabled"
} ;
}
2018-10-11 10:21:26 +02:00
}
}
2020-02-04 22:49:47 +01:00
} ) ( ) ;