/*
- Copyright (C) 2012-2019 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
*/
+
#include "content_menu.h"
-#include "lib/types.h"
-#include "lib/film.h"
+#include "lib/enum_indexed_vector.h"
+#include "lib/film_property.h"
+#include "lib/text_type.h"
+#include <dcp/warnings.h>
+LIBDCP_DISABLE_WARNINGS
#include <wx/splitter.h>
+LIBDCP_ENABLE_WARNINGS
#include <list>
+
+class AudioPanel;
+class ContentListCtrl;
+class ContentSubPanel;
+class Film;
+class FilmEditor;
+class FilmViewer;
+class LimitedContentPanelSplitter;
+class TextPanel;
+class TimelineDialog;
+class TimingPanel;
+class VideoPanel;
+class wxListCtrl;
+class wxListEvent;
class wxNotebook;
class wxPanel;
class wxSizer;
-class wxListCtrl;
-class wxListEvent;
class wxSplitterWindow;
-class TimelineDialog;
-class FilmEditor;
-class ContentSubPanel;
-class TextPanel;
-class VideoPanel;
-class AudioPanel;
-class TimingPanel;
-class Film;
-class FilmViewer;
-class LimitedSplitter : public wxSplitterWindow
+class ContentPanel
{
public:
- LimitedSplitter (wxWindow* parent);
-
- bool OnSashPositionChange (int new_position)
- {
- /* Try to stop the top bit of the splitter getting so small that buttons disappear */
- return new_position > 220;
- }
-
- void first_shown (wxWindow* top, wxWindow* bottom);
+ ContentPanel(wxNotebook *, std::shared_ptr<Film>, FilmViewer& viewer);
-private:
- void sized (wxSizeEvent& ev);
-
- bool _first_shown;
- int const _top_panel_minimum_size;
-};
-
-
-class ContentPanel : public boost::noncopyable
-{
-public:
- ContentPanel (wxNotebook *, std::shared_ptr<Film>, std::weak_ptr<FilmViewer> viewer);
+ ContentPanel (ContentPanel const&) = delete;
+ ContentPanel& operator= (ContentPanel const&) = delete;
std::shared_ptr<Film> film () const {
return _film;
void set_selection (ContentList cl);
void select_all ();
- void film_changed (Film::Property p);
+ void film_changed(FilmProperty p);
void film_content_changed (int p);
void first_shown ();
- wxWindow* window () const {
- return _splitter;
- }
+ wxWindow* window () const;
wxNotebook* notebook () const {
return _notebook;
bool remove_clicked (bool hotkey);
void timeline_clicked ();
- std::weak_ptr<FilmViewer> film_viewer () const {
+ FilmViewer& film_viewer() const {
return _film_viewer;
}
+ void add_files(std::vector<boost::filesystem::path> files);
+ void add_dcp(boost::filesystem::path dcp);
+ void add_folder(boost::filesystem::path folder);
+
boost::signals2::signal<void (void)> SelectionChanged;
private:
void setup ();
void setup_sensitivity ();
+ void set_selected_state(int item, bool state);
- void add_files (std::list<boost::filesystem::path>);
std::list<ContentSubPanel *> panels () const;
- LimitedSplitter* _splitter;
+ LimitedContentPanelSplitter* _splitter;
wxPanel* _top_panel;
wxNotebook* _notebook;
- wxListCtrl* _content;
+ ContentListCtrl* _content;
wxButton* _add_file;
wxButton* _add_folder;
wxButton* _add_dcp;
wxButton* _earlier;
wxButton* _later;
wxButton* _timeline;
- VideoPanel* _video_panel;
- AudioPanel* _audio_panel;
- TextPanel* _text_panel[static_cast<int>(TextType::COUNT)];
+ VideoPanel* _video_panel = nullptr;
+ AudioPanel* _audio_panel = nullptr;
+ EnumIndexedVector<TextPanel*, TextType> _text_panel;
TimingPanel* _timing_panel;
ContentMenu* _menu;
- TimelineDialog* _timeline_dialog;
+ wx_ptr<TimelineDialog> _timeline_dialog;
wxNotebook* _parent;
- wxWindow* _last_selected_tab;
+ wxWindow* _last_selected_tab = nullptr;
std::shared_ptr<Film> _film;
- std::weak_ptr<FilmViewer> _film_viewer;
+ FilmViewer& _film_viewer;
bool _generally_sensitive;
bool _ignore_deselect;
bool _no_check_selection;