X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fcontent_sub_panel.cc;h=e0a1a52bddac98382118852cc029b0c9c005c769;hb=a5d004b0773f633401528392fc28e66d70e13ac8;hp=674b3036976b2f68855739955d725fec6fa5e45c;hpb=f8e6fdee828647bc5a6a1cc7627052a072a37dc6;p=dcpomatic.git diff --git a/src/wx/content_sub_panel.cc b/src/wx/content_sub_panel.cc index 674b30369..e0a1a52bd 100644 --- a/src/wx/content_sub_panel.cc +++ b/src/wx/content_sub_panel.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2012-2014 Carl Hetherington + Copyright (C) 2012-2020 Carl Hetherington This file is part of DCP-o-matic. @@ -25,56 +25,45 @@ #include "lib/compose.hpp" #include "lib/log.h" #include -#include using std::list; using std::string; -using boost::shared_ptr; +using std::shared_ptr; +#if BOOST_VERSION >= 106100 +using namespace boost::placeholders; +#endif ContentSubPanel::ContentSubPanel (ContentPanel* p, wxString name) - : wxPanel (p->notebook(), wxID_ANY) + : wxScrolledWindow (p->notebook(), wxID_ANY) , _parent (p) , _sizer (new wxBoxSizer (wxVERTICAL)) + , _name (name) { - p->notebook()->AddPage (this, name, false); + SetScrollRate (8, 8); SetSizer (_sizer); + + _grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); + _sizer->Add (_grid, 0, wxALL, 8); } void -ContentSubPanel::setup_refer_button (wxCheckBox* button, shared_ptr dcp, bool can_reference, list why_not) const +ContentSubPanel::setup_refer_button (wxCheckBox* button, wxStaticText* note, shared_ptr dcp, bool can_reference, wxString cannot) const { - /* XXX: just for debugging */ - if (dcp) { - dcp->film()->log()->log ( - String::compose ( - "setup_refer_button for %1; %2 %3", - dcp->path(0).string(), - int(can_reference), - int(why_not.size())), - LogEntry::TYPE_GENERAL - ); - } - button->Enable (can_reference); - wxString s; - if (!dcp) { - s = _("No DCP selected."); - } else if (!can_reference) { - s = _("Cannot reference this DCP. "); - BOOST_FOREACH (string i, why_not) { - s += std_to_wx(i) + wxT(" "); - } + if (dcp && !can_reference) { + note->SetLabel (cannot); + } else { + note->SetLabel (wxT("")); } - /* XXX: more debugging */ - if (dcp) { - if (!s.IsEmpty()) { - dcp->film()->log()->log (String::compose ("setting tooltip to %1", wx_to_std (s)), LogEntry::TYPE_GENERAL); - } else { - dcp->film()->log()->log ("clearing tooltip", LogEntry::TYPE_GENERAL); - } + note->Wrap (400); + + if (cannot.IsEmpty()) { + note->Hide (); + } else { + note->Show (); } - button->SetToolTip (s); + _sizer->Layout (); }