diff --git a/Applications/ThemeEditor/main.cpp b/Applications/ThemeEditor/main.cpp index bf469286d3..0b6a762038 100644 --- a/Applications/ThemeEditor/main.cpp +++ b/Applications/ThemeEditor/main.cpp @@ -1,12 +1,48 @@ #include "PreviewWidget.h" #include #include +#include +#include +#include #include +class ColorRoleModel final : public GUI::Model { +public: + virtual int row_count(const GUI::ModelIndex&) const { return m_color_roles.size(); } + virtual int column_count(const GUI::ModelIndex&) const { return 1; } + virtual GUI::Variant data(const GUI::ModelIndex& index, GUI::ModelRole role = GUI::ModelRole::Display) const + { + if (role == GUI::ModelRole::Display) + return Gfx::to_string(m_color_roles[(size_t)index.row()]); + return {}; + } + virtual void update() { did_update(); } + + explicit ColorRoleModel(const Vector& color_roles) + : m_color_roles(color_roles) + { + } + + Gfx::ColorRole color_role(const GUI::ModelIndex& index) const + { + return m_color_roles[index.row()]; + } + + Gfx::ColorRole color_role(size_t index) const + { + return m_color_roles[index]; + } + +private: + const Vector& m_color_roles; +}; + int main(int argc, char** argv) { auto app = GUI::Application::construct(argc, argv); + Gfx::Palette preview_palette = app->palette(); + auto window = GUI::Window::construct(); auto& main_widget = window->set_main_widget(); main_widget.set_fill_with_background_color(true); @@ -16,7 +52,35 @@ int main(int argc, char** argv) preview_widget.set_preferred_size(480, 360); preview_widget.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fixed); - window->resize(500, 400); + auto& horizontal_container = main_widget.add(); + horizontal_container.set_layout(); + horizontal_container.set_preferred_size(0, 20); + horizontal_container.set_size_policy(GUI::SizePolicy::Fill, GUI::SizePolicy::Fixed); + + auto& combo_box = horizontal_container.add(); + auto& color_input = horizontal_container.add(); + + Vector color_roles; +#define __ENUMERATE_COLOR_ROLE(role) color_roles.append(Gfx::ColorRole::role); + ENUMERATE_COLOR_ROLES(__ENUMERATE_COLOR_ROLE) +#undef __ENUMERATE_COLOR_ROLE + + combo_box.set_only_allow_values_from_model(true); + combo_box.set_model(adopt(*new ColorRoleModel(color_roles))); + combo_box.on_change = [&](auto&, auto& index) { + auto role = static_cast(index.model())->color_role(index); + color_input.set_color(preview_palette.color(role)); + }; + + combo_box.set_selected_index((size_t)Gfx::ColorRole::Window - 1); + + color_input.on_change = [&] { + auto role = static_cast(combo_box.model())->color_role(combo_box.selected_index()); + preview_palette.set_color(role, color_input.color()); + preview_widget.set_preview_palette(preview_palette); + }; + + window->resize(500, 500); window->show(); return app->exec(); }