From af0a8c8a2d46cf0999d201cfb5be0b8c32dffc49 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Mon, 21 Dec 2020 23:51:24 +0100 Subject: Select newly-added cinemas. --- src/wx/screens_panel.cc | 23 ++++++++++++++++------- src/wx/screens_panel.h | 2 +- 2 files changed, 17 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/wx/screens_panel.cc b/src/wx/screens_panel.cc index 5541d46d4..36a4f67bc 100644 --- a/src/wx/screens_panel.cc +++ b/src/wx/screens_panel.cc @@ -115,7 +115,8 @@ ScreensPanel::setup_sensitivity () _remove_screen->Enable (_selected_screens.size() >= 1); } -void + +optional ScreensPanel::add_cinema (shared_ptr c) { string search = wx_to_std (_search->GetValue ()); @@ -125,20 +126,24 @@ ScreensPanel::add_cinema (shared_ptr c) string name = c->name; transform (name.begin(), name.end(), name.begin(), ::tolower); if (name.find (search) == string::npos) { - return; + return optional(); } } - _cinemas[_targets->AppendItem (_root, std_to_wx (c->name))] = c; + wxTreeItemId id = _targets->AppendItem(_root, std_to_wx(c->name)); - list > sc = c->screens (); - for (list >::iterator i = sc.begin(); i != sc.end(); ++i) { - add_screen (c, *i); + _cinemas[id] = c; + + BOOST_FOREACH (shared_ptr i, c->screens()) { + add_screen (c, i); } _targets->SortChildren (_root); + + return id; } + optional ScreensPanel::add_screen (shared_ptr c, shared_ptr s) { @@ -162,7 +167,11 @@ ScreensPanel::add_cinema_clicked () if (d->ShowModal () == wxID_OK) { shared_ptr c (new Cinema (d->name(), d->emails(), d->notes(), d->utc_offset_hour(), d->utc_offset_minute())); Config::instance()->add_cinema (c); - add_cinema (c); + optional id = add_cinema (c); + if (id) { + _targets->Unselect (); + _targets->SelectItem (*id); + } } d->Destroy (); diff --git a/src/wx/screens_panel.h b/src/wx/screens_panel.h index 9cf317c5a..69d74b13b 100644 --- a/src/wx/screens_panel.h +++ b/src/wx/screens_panel.h @@ -48,7 +48,7 @@ public: private: void add_cinemas (); - void add_cinema (boost::shared_ptr); + boost::optional add_cinema (boost::shared_ptr); boost::optional add_screen (boost::shared_ptr, boost::shared_ptr); void add_cinema_clicked (); void edit_cinema_clicked (); -- cgit v1.2.3