Fix alignment.
[dcpomatic.git] / src / wx / screens_panel.h
index 9cf317c5a143becc3489d5474977197ea89c714f..7703d69aad1cec27e1ebf90ec5a6fc6272d02036 100644 (file)
@@ -24,7 +24,6 @@ DCPOMATIC_DISABLE_WARNINGS
 DCPOMATIC_ENABLE_WARNINGS
 #include <wx/srchctrl.h>
 #include <wx/treectrl.h>
-#include <boost/shared_ptr.hpp>
 #include <boost/signals2.hpp>
 #include <list>
 #include <map>
@@ -33,23 +32,44 @@ namespace dcpomatic {
        class Screen;
 }
 
+
 class Cinema;
 
+
+/** Shim around wxTreeCtrl so we can use strcoll() to compare things */
+class TreeCtrl : public wxTreeCtrl
+{
+public:
+       wxDECLARE_DYNAMIC_CLASS (TreeCtrl);
+
+       TreeCtrl () {}
+
+       TreeCtrl (wxWindow* parent)
+               : wxTreeCtrl (parent, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTR_HIDE_ROOT | wxTR_MULTIPLE | wxTR_HAS_BUTTONS | wxTR_LINES_AT_ROOT)
+       {}
+
+       virtual ~TreeCtrl () {}
+
+private:
+       int OnCompareItems (wxTreeItemId const& a, wxTreeItemId const& b);
+};
+
+
 class ScreensPanel : public wxPanel
 {
 public:
        explicit ScreensPanel (wxWindow* parent);
        ~ScreensPanel ();
 
-       std::list<boost::shared_ptr<dcpomatic::Screen> > screens () const;
+       std::list<std::shared_ptr<dcpomatic::Screen>> screens () const;
        void setup_sensitivity ();
 
        boost::signals2::signal<void ()> ScreensChanged;
 
 private:
        void add_cinemas ();
-       void add_cinema (boost::shared_ptr<Cinema>);
-       boost::optional<wxTreeItemId> add_screen (boost::shared_ptr<Cinema>, boost::shared_ptr<dcpomatic::Screen>);
+       boost::optional<wxTreeItemId> add_cinema (std::shared_ptr<Cinema>);
+       boost::optional<wxTreeItemId> add_screen (std::shared_ptr<Cinema>, std::shared_ptr<dcpomatic::Screen>);
        void add_cinema_clicked ();
        void edit_cinema_clicked ();
        void remove_cinema_clicked ();
@@ -61,7 +81,7 @@ private:
        void search_changed ();
 
        wxSearchCtrl* _search;
-       wxTreeCtrl* _targets;
+       TreeCtrl* _targets;
        wxButton* _add_cinema;
        wxButton* _edit_cinema;
        wxButton* _remove_cinema;
@@ -70,8 +90,8 @@ private:
        wxButton* _remove_screen;
        wxTreeItemId _root;
 
-       typedef std::map<wxTreeItemId, boost::shared_ptr<Cinema> > CinemaMap;
-       typedef std::map<wxTreeItemId, boost::shared_ptr<dcpomatic::Screen> > ScreenMap;
+       typedef std::map<wxTreeItemId, std::shared_ptr<Cinema>> CinemaMap;
+       typedef std::map<wxTreeItemId, std::shared_ptr<dcpomatic::Screen>> ScreenMap;
 
        CinemaMap _cinemas;
        ScreenMap _screens;