katja: Update to ftxui 6

This commit is contained in:
Eugen Wissner 2025-04-07 22:59:26 +02:00
parent 24ecc7becd
commit de94f3d355
Signed by: belka
GPG Key ID: A27FDC1E8EE902C0
4 changed files with 40 additions and 21 deletions

View File

@ -1,6 +1,6 @@
FetchContent_Declare(ftxui FetchContent_Declare(ftxui
GIT_REPOSITORY https://github.com/ArthurSonzogni/ftxui GIT_REPOSITORY https://github.com/ArthurSonzogni/ftxui
GIT_TAG v5.0.0 GIT_TAG v6.0.2
GIT_PROGRESS TRUE GIT_PROGRESS TRUE
GIT_SHALLOW TRUE GIT_SHALLOW TRUE
EXCLUDE_FROM_ALL EXCLUDE_FROM_ALL

View File

@ -1,41 +1,58 @@
#include "component.hpp" #include "component.hpp"
#include <algorithm>
namespace katja namespace katja
{ {
PageContainer::PageContainer(std::vector<std::pair<std::string, Page>> pages) ScreenContainer::ScreenContainer(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter)
: on_enter(on_enter)
{ {
ftxui::Components menu_pages; ftxui::Components menu_pages;
std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(menu_entries), std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(menu_entries),
[](const std::pair<std::string, Page>& pair) { return pair.first; }); [](const std::pair<std::string, Page>& pair) { return pair.first; });
std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(menu_pages), std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(this->menu_pages),
[](const std::pair<std::string, Page>& pair) { return pair.second; }); [](const std::pair<std::string, Page>& pair) { return pair.second; });
std::copy(std::cbegin(this->menu_pages), std::cend(this->menu_pages), std::back_inserter(menu_pages));
ftxui::MenuOption menu_option = ftxui::MenuOption::Horizontal(); ftxui::MenuOption menu_option = ftxui::MenuOption::Horizontal();
this->menu = ftxui::Menu(&this->menu_entries, &this->menu_selected, menu_option); this->menu = ftxui::Toggle(&this->menu_entries, &this->menu_selected);
this->content = ftxui::Container::Tab(menu_pages, &this->menu_selected); this->content = ftxui::Container::Tab(std::move(menu_pages), &this->menu_selected);
} }
ftxui::Element PageContainer::Render() ftxui::Element ScreenContainer::OnRender()
{ {
return ftxui::vbox({ return ftxui::vbox({
this->menu->Render(), this->menu->Render(),
ftxui::separator(),
this->content->Render() this->content->Render()
}); });
} }
bool PageContainer::OnEvent(ftxui::Event event) bool ScreenContainer::OnEvent(ftxui::Event event)
{ {
if (event.character() == "q" && this->on_enter) if (event.character() == "q" && this->on_enter)
{ {
on_enter(); on_enter();
return true; return true;
} }
return menu->OnEvent(event); int previously = this->menu_selected;
bool result = menu->OnEvent(event);
if (previously != this->menu_selected)
{
this->menu_pages.at(this->menu_selected)->Load();
}
return result;
} }
ftxui::Element WelcomePage::Render() ftxui::Component Screen(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter)
{
return std::make_shared<ScreenContainer>(std::move(pages), on_enter);
}
ftxui::Element WelcomePage::OnRender()
{ {
return ftxui::text("Select an action in the menu."); return ftxui::text("Select an action in the menu.");
} }
@ -53,7 +70,7 @@ namespace katja
{ {
} }
ftxui::Element UpdatesPage::Render() ftxui::Element UpdatesPage::OnRender()
{ {
std::vector<std::shared_ptr<ftxui::Node>> lines; std::vector<std::shared_ptr<ftxui::Node>> lines;

View File

@ -1,6 +1,6 @@
#pragma once #pragma once
#include <algorithm> #include <ftxui/component/event.hpp>
#include <ftxui/component/component_base.hpp> #include <ftxui/component/component_base.hpp>
#include <ftxui/component/component.hpp> #include <ftxui/component/component.hpp>
@ -15,28 +15,31 @@ namespace katja
}; };
using Page = std::shared_ptr<PageBase>; using Page = std::shared_ptr<PageBase>;
using Pages = std::vector<Page>;
class PageContainer final : public ftxui::ComponentBase class ScreenContainer final : public ftxui::ComponentBase
{ {
int menu_selected{ 0 }; int menu_selected{ 0 };
ftxui::Component menu; ftxui::Component menu;
ftxui::Component content; ftxui::Component content;
std::vector<std::string> menu_entries; std::vector<std::string> menu_entries;
Pages menu_pages;
public:
std::function<void()> on_enter; std::function<void()> on_enter;
PageContainer(std::vector<std::pair<std::string, Page>> pages); public:
ScreenContainer(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter);
ftxui::Element Render() override; ftxui::Element OnRender() override;
bool OnEvent(ftxui::Event event) override; bool OnEvent(ftxui::Event event) override;
}; };
ftxui::Component Screen(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter);
class WelcomePage final : public PageBase class WelcomePage final : public PageBase
{ {
public: public:
void Load() override; void Load() override;
ftxui::Element Render() override; ftxui::Element OnRender() override;
}; };
class UpdatesPage final : public PageBase class UpdatesPage final : public PageBase
@ -47,7 +50,7 @@ namespace katja
explicit UpdatesPage(std::vector<package_identifier>&& updatable); explicit UpdatesPage(std::vector<package_identifier>&& updatable);
void Load() override; void Load() override;
ftxui::Element Render() override; ftxui::Element OnRender() override;
}; };
class SearchPage final : public PageBase class SearchPage final : public PageBase

View File

@ -21,12 +21,11 @@ int main(int argc, const char **argv)
auto screen = ftxui::ScreenInteractive::Fullscreen(); auto screen = ftxui::ScreenInteractive::Fullscreen();
auto container = std::make_shared<katja::PageContainer>(std::vector<std::pair<std::string, katja::Page>>{ auto container = Screen(std::vector<std::pair<std::string, katja::Page>>{
{ "Home", std::make_shared<katja::WelcomePage>() }, { "Home", std::make_shared<katja::WelcomePage>() },
{ "Updates", std::make_shared<katja::UpdatesPage>(std::move(updates)) }, { "Updates", std::make_shared<katja::UpdatesPage>(std::move(updates)) },
{ "Search", std::make_shared<katja::SearchPage>() } { "Search", std::make_shared<katja::SearchPage>() }
}); }, screen.ExitLoopClosure());
container->on_enter = screen.ExitLoopClosure();
screen.Loop(container); screen.Loop(container);
} }