2020-10-20 23:25:34 +02:00
/ * *
* @ name BetterSearchPage
2021-03-05 13:26:41 +01:00
* @ author DevilBro
2020-10-20 23:25:34 +02:00
* @ authorId 278543574059057154
2021-03-05 13:26:41 +01:00
* @ version 1.2 . 0
* @ description Adds some extra Controls to the Search Results Page
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/BetterSearchPage/
2021-03-10 09:17:37 +01:00
* @ updateUrl https : //mwittrien.github.io/BetterDiscordAddons/Plugins/BetterSearchPage/BetterSearchPage.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 = ( _ => {
2022-09-01 14:40:11 +02:00
const changeLog = {
2020-09-19 20:49:33 +02:00
} ;
2020-11-13 19:47:44 +01:00
2022-02-05 21:14:17 +01:00
return ! window . BDFDB _Global || ( ! window . BDFDB _Global . loaded && ! window . BDFDB _Global . started ) ? class {
2022-09-01 14:55:22 +02:00
constructor ( meta ) { for ( let key in meta ) this [ key ] = meta [ key ] ; }
getName ( ) { return this . name ; }
getAuthor ( ) { return this . author ; }
getVersion ( ) { return this . version ; }
getDescription ( ) { return ` The Library Plugin needed for ${ this . name } is missing. Open the Plugin Settings to download it. \n \n ${ this . description } ` ; }
2021-02-01 17:13:13 +01:00
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 ;
2022-09-01 14:55:22 +02:00
BdApi . showConfirmationModal ( "Library Missing" , ` The Library Plugin needed for ${ this . 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
} ) ;
2020-02-04 08:20:40 +01:00
}
2022-09-01 14:55:22 +02:00
if ( ! window . BDFDB _Global . pluginQueue . includes ( this . name ) ) window . BDFDB _Global . pluginQueue . push ( this . 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" ) ;
2022-09-01 14:55:22 +02: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 ${ this . 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 ] ) => {
2020-09-19 20:49:33 +02:00
var settings = { } ;
2020-10-09 21:09:35 +02:00
return class BetterSearchPage extends Plugin {
2021-01-06 12:38:36 +01:00
onLoad ( ) {
2020-09-19 20:49:33 +02:00
this . defaults = {
settings : {
2021-02-15 13:22:40 +01:00
addJumpTo : { value : true , description : "Add a Jump to Input Field (press enter to Jump)" } ,
cloneToTheTop : { value : true , description : "Clone the controls to the top of the Results Page" }
2020-09-19 20:49:33 +02:00
}
} ;
this . patchedModules = {
after : {
SearchResultsInner : "default"
}
} ;
}
2021-01-06 12:38:36 +01:00
onStart ( ) {
2020-06-08 20:07:08 +02:00
this . forceUpdateAll ( ) ;
2020-02-04 08:20:40 +01:00
}
2020-09-19 20:49:33 +02:00
2021-01-06 12:38:36 +01:00
onStop ( ) {
2020-06-08 20:07:08 +02:00
this . forceUpdateAll ( ) ;
2020-02-04 08:20:40 +01:00
}
2019-01-26 22:45:19 +01:00
2020-09-19 20:49:33 +02:00
getSettingsPanel ( collapseStates = { } ) {
let settingsPanel , settingsItems = [ ] ;
for ( let key in settings ) settingsItems . push ( BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . SettingsSaveItem , {
type : "Switch" ,
plugin : this ,
keys : [ "settings" , key ] ,
label : this . defaults . settings [ key ] . description ,
value : settings [ key ]
} ) ) ;
return settingsPanel = BDFDB . PluginUtils . createSettingsPanel ( this , settingsItems ) ;
}
2019-01-26 22:45:19 +01:00
2020-09-19 20:49:33 +02:00
onSettingsClosed ( e ) {
if ( this . SettingsUpdated ) {
delete this . SettingsUpdated ;
this . forceUpdateAll ( ) ;
}
}
2021-01-06 12:38:36 +01:00
forceUpdateAll ( ) {
2020-09-19 20:49:33 +02:00
settings = BDFDB . DataUtils . get ( this , "settings" ) ;
BDFDB . PatchUtils . forceAllUpdates ( this ) ;
2020-02-04 08:20:40 +01:00
}
2019-10-30 10:30:46 +01:00
2020-09-19 20:49:33 +02:00
processSearchResultsInner ( e ) {
if ( e . instance . props . search ) {
2020-11-19 16:51:14 +01:00
let [ children , index ] = BDFDB . ReactUtils . findParent ( e . returnvalue , { name : "SearchPagination" } ) ;
2020-09-19 20:49:33 +02:00
if ( index > - 1 ) {
let currentPage = parseInt ( Math . floor ( e . instance . props . search . offset / BDFDB . DiscordConstants . SEARCH _PAGE _SIZE ) ) + 1 ;
let maxPage = e . instance . props . search . totalResults > 5000 ? parseInt ( Math . ceil ( 5000 / BDFDB . DiscordConstants . SEARCH _PAGE _SIZE ) ) : parseInt ( Math . ceil ( e . instance . props . search . totalResults / BDFDB . DiscordConstants . SEARCH _PAGE _SIZE ) ) ;
2021-01-09 19:17:16 +01:00
children [ index ] . props . totalResults = children [ index ] . props . totalResults > 5000 ? 5000 : children [ index ] . props . totalResults ;
2020-09-19 20:49:33 +02:00
let pagination = children [ index ] . type ( children [ index ] . props ) ;
2021-02-15 13:23:46 +01:00
if ( ! pagination || maxPage < 2 ) return ;
2021-01-09 19:17:16 +01:00
pagination . props . className = BDFDB . DOMUtils . formatClassName ( pagination . props . className , BDFDB . disCN . pagination , BDFDB . disCN . _bettersearchpagepagination , settings . addJumpTo && BDFDB . disCN . paginationmini ) ;
2020-09-19 20:49:33 +02:00
if ( settings . addJumpTo ) {
2021-01-09 19:17:16 +01:00
pagination . props . children = [
pagination . props . children ,
BDFDB . ReactUtils . createElement ( BDFDB . LibraryComponents . TextInput , {
type : "number" ,
size : BDFDB . LibraryComponents . TextInput . Sizes . MINI ,
value : currentPage ,
min : 1 ,
max : maxPage ,
onKeyDown : ( event , instance ) => {
if ( event . which == 13 ) {
let page = instance . props . value < 1 ? 1 : ( instance . props . value > maxPage ? maxPage : instance . props . value ) ;
if ( page < currentPage ) BDFDB . LibraryModules . SearchPageUtils . searchPreviousPage ( e . instance . props . searchId , ( currentPage - page ) * BDFDB . DiscordConstants . SEARCH _PAGE _SIZE ) ;
else if ( page > currentPage ) BDFDB . LibraryModules . SearchPageUtils . searchNextPage ( e . instance . props . searchId , ( page - currentPage ) * BDFDB . DiscordConstants . SEARCH _PAGE _SIZE ) ;
}
}
2020-09-19 20:49:33 +02:00
} )
2021-01-09 19:17:16 +01:00
] . flat ( 10 ) . filter ( n => n ) ;
2020-09-19 20:49:33 +02:00
}
children [ index ] = pagination ;
2021-01-09 19:17:16 +01:00
if ( settings . cloneToTheTop ) {
2021-02-15 13:22:40 +01:00
let topPagination = BDFDB . ReactUtils . cloneElement ( pagination ) ;
topPagination . props . className = BDFDB . DOMUtils . formatClassName ( topPagination . props . className , BDFDB . disCN . paginationtop ) ;
children . unshift ( topPagination ) ;
2021-01-09 19:17:16 +01:00
}
pagination . props . className = BDFDB . DOMUtils . formatClassName ( pagination . props . className , BDFDB . disCN . paginationbottom ) ;
2020-02-04 08:20:40 +01:00
}
}
2019-10-28 10:52:09 +01:00
}
2020-09-19 20:49:33 +02:00
} ;
2022-09-01 14:40:11 +02:00
} ) ( window . BDFDB _Global . PluginUtils . buildPlugin ( changeLog ) ) ;
2020-09-19 20:49:33 +02:00
} ) ( ) ;