From 3a8d014514fcb9cb660c8dd1805b224e2d94a9f4 Mon Sep 17 00:00:00 2001 From: Dylan Date: Wed, 2 Oct 2024 21:06:04 +0000 Subject: [PATCH] add custom image support in component selection --- source/main.cpp | 1 - source/view/icon_part_select.cpp | 76 ++++++++++++++++++++++---------- source/view/main_view.cpp | 3 +- 3 files changed, 54 insertions(+), 26 deletions(-) diff --git a/source/main.cpp b/source/main.cpp index d11020b..4242ee3 100644 --- a/source/main.cpp +++ b/source/main.cpp @@ -74,7 +74,6 @@ int main(int argc, char *argv[]) return EXIT_FAILURE; } - brls::Logger::setLogLevel(brls::LogLevel::LOG_DEBUG); brls::Application::createWindow("demo/title"_i18n); brls::Application::getPlatform()->setThemeVariant(brls::ThemeVariant::DARK); diff --git a/source/view/icon_part_select.cpp b/source/view/icon_part_select.cpp index 1af57f3..2bc283f 100644 --- a/source/view/icon_part_select.cpp +++ b/source/view/icon_part_select.cpp @@ -1,12 +1,14 @@ #include "view/icon_part_select.hpp" #include "view/icon_part_select_grid.hpp" +#include "view/empty_message.hpp" #include #include "util/paths.hpp" #include #include +using namespace brls::literals; namespace fs = std::filesystem; RecyclerCell::RecyclerCell() @@ -40,7 +42,13 @@ std::string convertName(std::string name) RecyclingGridItem *DataSource::cellForRow(RecyclingGrid *recycler, size_t index) { RecyclerCell *item = (RecyclerCell *)recycler->dequeueReusableCell("Cell"); - item->label->setText(convertName(parts[index].name)); + if (parts[index].name == "none") { + item->label->setText("app/settings/icon_cache/none"_i18n); + } else if (parts[index].name == "custom") { + item->label->setText("app/main/custom_image"_i18n); + } else{ + item->label->setText(convertName(parts[index].name)); + } item->image->setImageFromFile(parts[index].icon); return item; } @@ -49,34 +57,54 @@ void DataSource::onItemSelected(RecyclingGrid *recycler, size_t index) { brls::Logger::info("Selected {} ({})", parts[index].name, parts[index].icon); - if (parts[index].name == "none") + if (parts[index].name == "none" && parent) { - if (parent) + onSelected(""); + parent->dismiss(); + return; + } else if (parts[index].name == "custom" && parent) { + auto files = std::ranges::subrange(fs::directory_iterator(fs::path(paths::BasePath)), fs::directory_iterator{}) | + std::views::filter([](const fs::directory_entry &entry) { return entry.is_regular_file() && (entry.path().extension() == ".png" || entry.path().extension() == ".jpg" || entry.path().extension() == ".jpeg"); }) | + std::views::transform([](const fs::directory_entry &entry) { return entry.path().string(); }) | + std::ranges::to>(); + + for (auto &file : files) { - onSelected(""); - parent->dismiss(); - return; + brls::Logger::debug("{}", file); } - } - - auto files = std::ranges::subrange(fs::directory_iterator(fs::path(paths::IconCachePath) / parts[index].name / subcategory), fs::directory_iterator{}) | - std::views::filter([](const fs::directory_entry &entry) { return entry.is_regular_file() && entry.path().extension() == ".png"; }) | - std::views::transform([](const fs::directory_entry &entry) { return entry.path().string(); }) | - std::ranges::to>(); - - for (auto &file : files) - { - brls::Logger::debug("{}", file); - } - brls::Logger::debug("total {}", files.size()); + brls::Logger::debug("total {}", files.size()); + + if (files.empty()) { + recycler->present(new EmptyMessage(fmt::format(fmt::runtime("app/errors/nothing_images"_i18n), paths::BasePath))); + } else { + recycler->present(new grid::IconPartSelectGrid(files, "app/main/available_images"_i18n, state, [this](std::string icon) + { + onSelected(icon); + if (parent) + { + parent->dismiss(); + } }, onFocused)); + } + } else { + auto files = std::ranges::subrange(fs::directory_iterator(fs::path(paths::IconCachePath) / parts[index].name / subcategory), fs::directory_iterator{}) | + std::views::filter([](const fs::directory_entry &entry) { return entry.is_regular_file() && entry.path().extension() == ".png"; }) | + std::views::transform([](const fs::directory_entry &entry) { return entry.path().string(); }) | + std::ranges::to>(); - recycler->present(new grid::IconPartSelectGrid(files, convertName(parts[index].name), state, [this](std::string icon) - { - onSelected(icon); - if (parent) + for (auto &file : files) { - parent->dismiss(); - } }, onFocused)); + brls::Logger::debug("{}", file); + } + brls::Logger::debug("total {}", files.size()); + + recycler->present(new grid::IconPartSelectGrid(files, convertName(parts[index].name), state, [this](std::string icon) + { + onSelected(icon); + if (parent) + { + parent->dismiss(); + } }, onFocused)); + } } size_t DataSource::getItemCount() diff --git a/source/view/main_view.cpp b/source/view/main_view.cpp index 95b2f42..83c06fb 100644 --- a/source/view/main_view.cpp +++ b/source/view/main_view.cpp @@ -52,6 +52,8 @@ std::expected, std::string> getCategories(std::string_ if (res.empty()) { return std::unexpected("No categories found"); } else { + // this is slow/stupid but it doesn't matter + res.insert(res.begin(), CategoryPart{"custom", ""}); res.insert(res.begin(), CategoryPart{"none", ""}); return res; } @@ -226,7 +228,6 @@ MainView::MainView() brls::sync([]() { brls::Logger::info("{} the debug layer", true ? "Open" : "Close"); }); - brls::Application::enableDebuggingView(true); handleUserSelection(); }