e0111b6c524b64b90355c41c5ece042fb8c85202
[dcpomatic.git] / src / wx / kdm_dialog.h
1 /*
2     Copyright (C) 2012 Carl Hetherington <cth@carlh.net>
3
4     This file is part of DCP-o-matic.
5
6     DCP-o-matic is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     DCP-o-matic is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
18
19 */
20
21 #include "wx_util.h"
22 #include <dcp/types.h>
23 #include <wx/wx.h>
24 #include <boost/shared_ptr.hpp>
25 #include <boost/date_time/posix_time/posix_time.hpp>
26 #include <map>
27
28 class Cinema;
29 class Screen;
30 class Film;
31 class ScreensPanel;
32 class KDMTimingPanel;
33 class KDMOutputPanel;
34 class KDMCPLPanel;
35 struct CPLSummary;
36
37 class KDMDialog : public wxDialog
38 {
39 public:
40         KDMDialog (wxWindow *, boost::shared_ptr<const Film>);
41
42         std::list<boost::shared_ptr<Screen> > screens () const;
43         /** @return KDM from time in local time; note that ptime has no time zone information */
44         boost::posix_time::ptime from () const;
45         /** @return KDM until time in local time; note that ptime has no time zone information */
46         boost::posix_time::ptime until () const;
47
48         boost::filesystem::path cpl () const;
49
50         boost::filesystem::path directory () const;
51         bool write_to () const;
52         dcp::Formulation formulation () const;
53
54 private:
55         void setup_sensitivity ();
56
57         ScreensPanel* _screens;
58         KDMTimingPanel* _timing;
59         KDMCPLPanel* _cpl;
60         KDMOutputPanel* _output;
61 };