Merge remote-tracking branch 'origin/master' into 2.0
[dcpomatic.git] / src / wx / kdm_dialog.h
index 99e2603380128e5fa22edc20a87f4bd08972ce3a..0fc95db8443dee447023e7170b3ee964c0daef85 100644 (file)
 
 #include <map>
 #include <boost/shared_ptr.hpp>
+#include <boost/date_time/posix_time/posix_time.hpp>
 #include <wx/wx.h>
 #include <wx/treectrl.h>
+#include "wx_util.h"
 
 class wxTreeCtrl;
 class wxDatePickerCtrl;
@@ -34,21 +36,37 @@ class Screen;
 class KDMDialog : public wxDialog
 {
 public:
-       KDMDialog (wxWindow *);
+       KDMDialog (wxWindow *, boost::shared_ptr<const Film>);
+
+       std::list<boost::shared_ptr<Screen> > screens () const;
+
+       /** @return KDM from time in local time */
+       boost::posix_time::ptime from () const;
+       /** @return KDM until time in local time */
+       boost::posix_time::ptime until () const;
+       
+       boost::filesystem::path cpl () const;
+       boost::filesystem::path directory () const;
+       bool write_to () const;
+       dcp::Formulation formulation () const;
 
 private:
        void add_cinema (boost::shared_ptr<Cinema>);
        void add_screen (boost::shared_ptr<Cinema>, boost::shared_ptr<Screen>);
-       void targets_selection_changed (wxCommandEvent &);
-       void add_cinema_clicked (wxCommandEvent &);
-       void edit_cinema_clicked (wxCommandEvent &);
-       void remove_cinema_clicked (wxCommandEvent &);
-       void add_screen_clicked (wxCommandEvent &);
-       void edit_screen_clicked (wxCommandEvent &);
-       void remove_screen_clicked (wxCommandEvent &);
+       void add_cinema_clicked ();
+       void edit_cinema_clicked ();
+       void remove_cinema_clicked ();
+       void add_screen_clicked ();
+       void edit_screen_clicked ();
+       void remove_screen_clicked ();
        std::list<std::pair<wxTreeItemId, boost::shared_ptr<Cinema> > > selected_cinemas () const;
        std::list<std::pair<wxTreeItemId, boost::shared_ptr<Screen> > > selected_screens () const;
        void setup_sensitivity ();
+       void update_cpl_choice ();
+       void update_cpl_summary ();
+       void cpl_browse_clicked ();
+
+       static boost::posix_time::ptime posix_time (wxDatePickerCtrl *, wxTimePickerCtrl *);
        
        wxTreeCtrl* _targets;
        wxButton* _add_cinema;
@@ -61,13 +79,22 @@ private:
        wxDatePickerCtrl* _until_date;
        wxTimePickerCtrl* _from_time;
        wxTimePickerCtrl* _until_time;
-#ifdef __WXMSW__       
+       wxChoice* _cpl;
+       wxButton* _cpl_browse;
+       wxStaticText* _dcp_directory;
+       wxStaticText* _cpl_id;
+       wxStaticText* _cpl_annotation_text;
+       wxChoice* _type;
+       wxRadioButton* _write_to;
+#ifdef DCPOMATIC_USE_OWN_DIR_PICKER
        DirPickerCtrl* _folder;
 #else
        wxDirPickerCtrl* _folder;
 #endif
+       wxRadioButton* _email;
 
        wxTreeItemId _root;
        std::map<wxTreeItemId, boost::shared_ptr<Cinema> > _cinemas;
        std::map<wxTreeItemId, boost::shared_ptr<Screen> > _screens;
+       std::vector<CPLSummary> _cpls;
 };