module.exports = (Plugin, Api, Vendor) => { if (!global.BDFDB || typeof BDFDB != "object") global.BDFDB = {myPlugins:{}, BDv2Api: Api}; return class extends Plugin { initConstructor () { this.patchModules = { "SearchResults":["componentDidMount","componentDidUpdate"] }; this.css = ` .BSP-pagination-button { background: url('data:image/svg+xml; utf8, ') 50%/9px 12px no-repeat; border: 1px solid rgba(79,84,92,.16); border-radius: 2px; cursor: pointer; height: 18px; left: 20px; opacity: .7; top: 20px; width: 18px; } ${BDFDB.dotCN.themedark} .BSP-pagination-button { background-image: url('data:image/svg+xml; utf8, '); border: 1px solid hsla(0,0%,100%,.16); } .BSP-pagination-button.BSP-pagination-first { margin-right: 10px; transform: rotate(180deg); } .BSP-pagination-button.BSP-pagination-last { margin-left: 10px; margin-right: 10px; } .BSP-pagination-button.BSP-pagination-jump { margin-left: 10px; transform: rotate(90deg); } .BSP-pagination-button${BDFDB.dotCN.searchresultspaginationdisabled} { cursor: default; opacity: .3; } .BSP-pagination-button${BDFDB.notCN.searchresultspaginationdisabled}:hover { opacity: 1; } `; this.defaults = { settings: { addFirstLast: {value:true, description:"Adds a first and last page button."}, addJumpTo: {value:true, description:"Adds a jump to input field (press enter to jump)."}, cloneToTheTop: {value:true, description:"Clones the controls to the top of the results page."} } }; } onStart () { if (global.BDFDB && global.BDFDB.myPlugins && typeof global.BDFDB.myPlugins == "object") global.BDFDB.myPlugins[this.name] = this; var libraryScript = document.querySelector('head script[src="https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"]'); if (!global.BDFDB || typeof BDFDB != "object" || performance.now() - BDFDB.creationTime > 600000) { if (libraryScript) libraryScript.remove(); libraryScript = document.createElement("script"); libraryScript.setAttribute("type", "text/javascript"); libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"); libraryScript.setAttribute("date", performance.now()); libraryScript.addEventListener("load", () => {if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize();}); document.head.appendChild(libraryScript); } else if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize(); this.startTimeout = setTimeout(() => {this.initialize();}, 30000); } initialize () { if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) { if (this.started) return true; BDFDB.loadMessage(this); this.SearchNavigation = BDFDB.WebModules.findByProperties("searchNextPage","searchPreviousPage"); BDFDB.WebModules.forceAllUpdates(this); return true; } else { console.error(`%c[${this.name}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not load BD functions!'); return false; } } onStop () { if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) { BDFDB.removeEles(".BSP-pagination",".BSP-pagination-button",".BSP-pagination-jumpinput"); BDFDB.unloadMessage(this); return true; } else { return false; } } // begin of own functions processSearchResults (instance, wrapper) { if (instance.props && instance.props.searchId) this.addNewControls(wrapper.querySelector(BDFDB.dotCN.searchresultspagination), instance.props.searchId); } addNewControls (pagination, searchId) { if (!pagination || !searchId || document.querySelector(".BSP-pagination, .BSP-pagination-button, .BSP-pagination-jumpinput")) return; let searchResultsWrapper = BDFDB.getParentEle(BDFDB.dotCN.searchresultswrapper, pagination); if (!searchResultsWrapper) return; let currentpage, maxpage; for (let word of pagination.textContent.split(" ")) { let number = parseInt(word.replace(/\./g,"")); if (!isNaN(number) && !currentpage) currentpage = number; else if (!isNaN(number)) { maxpage = number; break; } } if (!currentpage || !maxpage) return; let temppage = currentpage; currentpage = currentpage < maxpage ? currentpage : maxpage; maxpage = temppage < maxpage ? maxpage : temppage; if (maxpage > 201) { if (currentpage == 201) BDFDB.showToast("Discord doesn't allow you to go further than page 201.",{type:"error"}); maxpage = 201; } if (currentpage == maxpage && maxpage == 201) BDFDB.addClass(pagination.querySelector(BDFDB.dotCN.searchresultspaginationnext), BDFDB.disCN.searchresultspaginationdisabled); let settings = BDFDB.getAllData(this, "settings"); for (let btn of pagination.querySelectorAll(BDFDB.dotCNC.searchresultspaginationprevious + BDFDB.dotCN.searchresultspaginationnext)) BDFDB.addClass(btn, "pagination-button"); if (settings.addFirstLast) { pagination.insertBefore(BDFDB.htmlToElement(`
`), pagination.firstElementChild); pagination.appendChild(BDFDB.htmlToElement(`
`)); } if (settings.addJumpTo) { pagination.appendChild(BDFDB.htmlToElement(`
`)); pagination.appendChild(BDFDB.htmlToElement(`
`)); } BDFDB.initElements(pagination, this); if (settings.cloneToTheTop) { let BSPpaginaton = pagination.cloneNode(true); BDFDB.addClass(BSPpaginaton, "BSP-pagination"); searchResultsWrapper.insertBefore(BSPpaginaton, searchResultsWrapper.firstElementChild); BDFDB.initElements(BSPpaginaton, this); } var doJump = (input) => { let value = input.value; if (value < 1 || value > maxpage) { input.value = currentpage; if (maxpage == 201 && value > maxpage) BDFDB.showToast("Discord doesn't allow you to go further than page 201.",{type:"error"}); } else if (value < currentpage) { for (; currentpage - value > 0; value++) { this.SearchNavigation.searchPreviousPage(searchId); } } else if (value > currentpage) { for (; value - currentpage > 0; value--) { this.SearchNavigation.searchNextPage(searchId); } } }; BDFDB.addEventListener(this, searchResultsWrapper, "click", BDFDB.dotCN.searchresultspaginationdisabled, e => { e.preventDefault(); e.stopPropagation(); }); BDFDB.addEventListener(this, searchResultsWrapper, "click", `.BSP-pagination ${BDFDB.dotCN.searchresultspaginationprevious + BDFDB.notCN.searchresultspaginationdisabled}`, () => { this.SearchNavigation.searchPreviousPage(searchId); }); BDFDB.addEventListener(this, searchResultsWrapper, "click", `.BSP-pagination ${BDFDB.dotCN.searchresultspaginationnext + BDFDB.notCN.searchresultspaginationdisabled}`, () => { this.SearchNavigation.searchNextPage(searchId); }); BDFDB.addEventListener(this, searchResultsWrapper, "click", `.BSP-pagination-first${BDFDB.notCN.searchresultspaginationdisabled}`, () => { for (let i = 0; currentpage - 1 - i > 0; i++) this.SearchNavigation.searchPreviousPage(searchId); }); BDFDB.addEventListener(this, searchResultsWrapper, "click", `.BSP-pagination-last${BDFDB.notCN.searchresultspaginationdisabled}`, () => { for (let i = 0; maxpage - currentpage - i > 0; i++) this.SearchNavigation.searchNextPage(searchId); }); BDFDB.addEventListener(this, searchResultsWrapper, "click", `.BSP-pagination-jump${BDFDB.notCN.searchresultspaginationdisabled}`, e => { doJump(e.currentTarget.parentElement.querySelector(`.BSP-pagination-jumpinput ${BDFDB.dotCN.inputmini}`)); }); BDFDB.addEventListener(this, searchResultsWrapper, "keydown", `.BSP-pagination-jumpinput ${BDFDB.dotCN.inputmini}`, e => { let label = e.currentTarget.getAttribute("aria-label"); if (label) BDFDB.createTooltip(label, e.currentTarget, {type:"top"}); }); BDFDB.addEventListener(this, searchResultsWrapper, "mouseenter", `.pagination-button${BDFDB.notCN.searchresultspaginationdisabled}`, e => { let label = e.currentTarget.getAttribute("aria-label"); if (label) BDFDB.createTooltip(label, e.currentTarget, {type:"top"}); }); } getSettingsPanel () { if (!global.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return; var settings = BDFDB.getAllData(this, "settings"); var settingshtml = `
${this.name}
`; for (let key in settings) { settingshtml += `

${this.defaults.settings[key].description}

`; } settingshtml += `
`; let settingspanel = BDFDB.htmlToElement(settingshtml); BDFDB.initElements(settingspanel, this); return settingspanel; } onSettingsClosed () { if (this.SettingsUpdated) { delete this.SettingsUpdated; BDFDB.removeEles(".BSP-pagination",".BSP-pagination-button",".BSP-pagination-jumpinput"); BDFDB.WebModules.forceAllUpdates(this); } } } };