Skip to content

Commit

Permalink
GamesSettings: Always ensure last card back selected is saved
Browse files Browse the repository at this point in the history
  • Loading branch information
ne0ndrag0n authored and AtkinsSJ committed Sep 20, 2022
1 parent 42865b8 commit b16704d
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 2 deletions.
11 changes: 9 additions & 2 deletions Userland/Applications/GamesSettings/CardSettingsWidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,12 +43,16 @@ CardSettingsWidget::CardSettingsWidget()
if (!set_card_back_image_path(Config::read_string("Games"sv, "Cards"sv, "CardBackImage"sv)))
set_card_back_image_path(default_card_back_image_path);
m_card_back_image_view->on_selection_change = [&]() {
if (m_card_back_image_view->selection().is_empty())
auto& card_back_selection = m_card_back_image_view->selection();
if (card_back_selection.is_empty())
return;
m_last_selected_card_back = card_back_selection.first();
set_modified(true);
Cards::CardPainter::the().set_background_image_path(card_back_image_path());
m_preview_card_back->update();
};

m_last_selected_card_back = m_card_back_image_view->selection().first();
}

void CardSettingsWidget::apply_settings()
Expand Down Expand Up @@ -84,6 +88,9 @@ bool CardSettingsWidget::set_card_back_image_path(String const& path)

String CardSettingsWidget::card_back_image_path() const
{
auto card_back_image_index = m_card_back_image_view->selection().first();
auto& card_back_selection = m_card_back_image_view->selection();
GUI::ModelIndex card_back_image_index = m_last_selected_card_back;
if (!card_back_selection.is_empty())
card_back_image_index = card_back_selection.first();
return static_cast<GUI::FileSystemModel const*>(m_card_back_image_view->model())->full_path(card_back_image_index);
}
3 changes: 3 additions & 0 deletions Userland/Applications/GamesSettings/CardSettingsWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#include <LibGUI/Frame.h>
#include <LibGUI/IconView.h>
#include <LibGUI/ImageWidget.h>
#include <LibGUI/ModelIndex.h>
#include <LibGUI/SettingsWindow.h>

class CardSettingsWidget final : public GUI::SettingsWindow::Tab {
Expand All @@ -34,4 +35,6 @@ class CardSettingsWidget final : public GUI::SettingsWindow::Tab {

RefPtr<GUI::ColorInput> m_background_color_input;
RefPtr<GUI::IconView> m_card_back_image_view;

GUI::ModelIndex m_last_selected_card_back;
};

0 comments on commit b16704d

Please sign in to comment.