PlainText -> PlainTextFile.
[dcpomatic.git] / src / wx / content_sub_panel.cc
index 8679604cbc3af0550fb4e022e0dd1ffefc51fcc0..93296d5b97999c67b8e4e49bfb99feb06fb3b19c 100644 (file)
@@ -32,39 +32,37 @@ using std::string;
 using boost::shared_ptr;
 
 ContentSubPanel::ContentSubPanel (ContentPanel* p, wxString name)
-       : wxPanel (p->notebook(), wxID_ANY)
+       : wxScrolledWindow (p->notebook(), wxID_ANY)
        , _parent (p)
        , _sizer (new wxBoxSizer (wxVERTICAL))
 {
        p->notebook()->AddPage (this, name, false);
+       SetScrollRate (-1, 8);
        SetSizer (_sizer);
 }
 
 void
-ContentSubPanel::setup_refer_button (wxCheckBox* button, shared_ptr<DCPContent> dcp, bool can_reference, list<string> why_not) const
+ContentSubPanel::setup_refer_button (wxCheckBox* button, wxStaticText* note, shared_ptr<DCPContent> dcp, bool can_reference, string why_not) 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) {
+               if (why_not.empty()) {
+                       s = _("Cannot reference this DCP.");
+               } else {
+                       s = _("Cannot reference this DCP: ") + std_to_wx(why_not);
                }
        }
-       button->SetToolTip (s);
+
+       note->SetLabel (s);
+       note->Wrap (400);
+
+       if (s.IsEmpty ()) {
+               note->Hide ();
+       } else {
+               note->Show ();
+       }
+
+       _sizer->Layout ();
 }