Skip to content

Commit

Permalink
add option for single-page local mods list
Browse files Browse the repository at this point in the history
  • Loading branch information
HJfod committed Nov 10, 2024
1 parent a3b306a commit efb1fbf
Show file tree
Hide file tree
Showing 6 changed files with 38 additions and 13 deletions.
6 changes: 6 additions & 0 deletions loader/resources/mod.json.in
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,12 @@
"name": "Enable Geode-Themed Colors",
"description": "When enabled, the Geode menu has a <ca>Geode-themed color scheme</c>. <cy>This does not affect any other menus!</c>"
},
"infinite-local-mods-list": {
"type": "bool",
"default": false,
"name": "Expand Installed Mods List",
"description": "Make the installed mods list a single infinite scrollable list instead of having pages"
},
"developer-title": {
"type": "title",
"name": "Developer Settings"
Expand Down
19 changes: 17 additions & 2 deletions loader/src/ui/mods/sources/InstalledModListSource.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,15 @@ void InstalledModListSource::resetQuery() {
};
}

InstalledModListSource::ProviderTask InstalledModListSource::fetchPage(size_t page, size_t pageSize, bool forceUpdate) {
InstalledModListSource::ProviderTask InstalledModListSource::fetchPage(size_t page, bool forceUpdate) {
m_query.page = page;
m_query.pageSize = pageSize;
m_query.pageSize = m_pageSize;

// Infinite mods list option
if (Mod::get()->template getSettingValue<bool>("infinite-local-mods-list")) {
m_query.page = 0;
m_query.pageSize = Loader::get()->getAllMods().size();
}

auto content = ModListSource::ProvidedMods();
for (auto& mod : Loader::get()->getAllMods()) {
Expand Down Expand Up @@ -122,3 +128,12 @@ InvalidateQueryAfter<InstalledModsQuery> InstalledModListSource::getQueryMut() {
bool InstalledModListSource::isDefaultQuery() const {
return m_query.isDefault();
}

$execute {
listenForSettingChanges("infinite-local-mods-list", [](bool value) {
auto size = value ? std::numeric_limits<size_t>::max() : 10;
InstalledModListSource::get(InstalledModListType::All)->setPageSize(size);
InstalledModListSource::get(InstalledModListType::OnlyErrors)->setPageSize(size);
// Updates is technically a server mod list :-) So I left it out here
});
}
10 changes: 6 additions & 4 deletions loader/src/ui/mods/sources/ModListSource.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@
#define FTS_FUZZY_MATCH_IMPLEMENTATION
#include <Geode/external/fts/fts_fuzzy_match.h>

static constexpr size_t PER_PAGE = 10;
static std::vector<ModListSource*> ALL_EXTANT_SOURCES {};

static size_t ceildiv(size_t a, size_t b) {
Expand Down Expand Up @@ -33,7 +32,7 @@ typename ModListSource::PageLoadTask ModListSource::loadPage(size_t page, bool f
return PageLoadTask::immediate(Ok(m_cachedPages.at(page)));
}
m_cachedPages.erase(page);
return this->fetchPage(page, PER_PAGE, forceUpdate).map(
return this->fetchPage(page, forceUpdate).map(
[this, page](Result<ProvidedMods, LoadPageError>* result) -> Result<Page, LoadPageError> {
if (result->isOk()) {
auto data = result->unwrap();
Expand All @@ -56,12 +55,15 @@ typename ModListSource::PageLoadTask ModListSource::loadPage(size_t page, bool f
}

std::optional<size_t> ModListSource::getPageCount() const {
return m_cachedItemCount ? std::optional(ceildiv(m_cachedItemCount.value(), PER_PAGE)) : std::nullopt;
return m_cachedItemCount ? std::optional(ceildiv(m_cachedItemCount.value(), m_pageSize)) : std::nullopt;
}

std::optional<size_t> ModListSource::getItemCount() const {
return m_cachedItemCount;
}
void ModListSource::setPageSize(size_t size) {
m_pageSize = size;
this->reset();
}

void ModListSource::reset() {
this->resetQuery();
Expand Down
10 changes: 6 additions & 4 deletions loader/src/ui/mods/sources/ModListSource.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -51,9 +51,10 @@ class ModListSource {
protected:
std::unordered_map<size_t, Page> m_cachedPages;
std::optional<size_t> m_cachedItemCount;
size_t m_pageSize = 10;

virtual void resetQuery() = 0;
virtual ProviderTask fetchPage(size_t page, size_t pageSize, bool forceUpdate) = 0;
virtual ProviderTask fetchPage(size_t page, bool forceUpdate) = 0;
virtual void setSearchQuery(std::string const& query) = 0;

ModListSource();
Expand All @@ -75,6 +76,7 @@ class ModListSource {
PageLoadTask loadPage(size_t page, bool forceUpdate = false);
std::optional<size_t> getPageCount() const;
std::optional<size_t> getItemCount() const;
void setPageSize(size_t size);

static void clearAllCaches();
static bool isRestartRequired();
Expand Down Expand Up @@ -123,7 +125,7 @@ class InstalledModListSource : public ModListSource {
InstalledModsQuery m_query;

void resetQuery() override;
ProviderTask fetchPage(size_t page, size_t pageSize, bool forceUpdate) override;
ProviderTask fetchPage(size_t page, bool forceUpdate) override;
void setSearchQuery(std::string const& query) override;

InstalledModListSource(InstalledModListType type);
Expand Down Expand Up @@ -153,7 +155,7 @@ class ServerModListSource : public ModListSource {
server::ModsQuery m_query;

void resetQuery() override;
ProviderTask fetchPage(size_t page, size_t pageSize, bool forceUpdate) override;
ProviderTask fetchPage(size_t page, bool forceUpdate) override;
void setSearchQuery(std::string const& query) override;

ServerModListSource(ServerModListType type);
Expand All @@ -174,7 +176,7 @@ class ServerModListSource : public ModListSource {
class ModPackListSource : public ModListSource {
protected:
void resetQuery() override;
ProviderTask fetchPage(size_t page, size_t pageSize, bool forceUpdate) override;
ProviderTask fetchPage(size_t page, bool forceUpdate) override;
void setSearchQuery(std::string const& query) override;

ModPackListSource();
Expand Down
2 changes: 1 addition & 1 deletion loader/src/ui/mods/sources/ModPackListSource.cpp
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#include "ModListSource.hpp"

void ModPackListSource::resetQuery() {}
ModPackListSource::ProviderTask ModPackListSource::fetchPage(size_t page, size_t pageSize, bool forceUpdate) {
ModPackListSource::ProviderTask ModPackListSource::fetchPage(size_t page, bool forceUpdate) {
return ProviderTask::immediate(Err(LoadPageError("Coming soon ;)")));
}

Expand Down
4 changes: 2 additions & 2 deletions loader/src/ui/mods/sources/ServerModListSource.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@ void ServerModListSource::resetQuery() {
m_query = this->createDefaultQuery();
}

ServerModListSource::ProviderTask ServerModListSource::fetchPage(size_t page, size_t pageSize, bool forceUpdate) {
ServerModListSource::ProviderTask ServerModListSource::fetchPage(size_t page, bool forceUpdate) {
m_query.page = page;
m_query.pageSize = pageSize;
m_query.pageSize = m_pageSize;
return server::getMods(m_query, !forceUpdate).map(
[](Result<server::ServerModsList, server::ServerError>* result) -> ProviderTask::Value {
if (result->isOk()) {
Expand Down

0 comments on commit efb1fbf

Please sign in to comment.