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))
+ , _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);
+
+ _config_connection = Config::instance()->Changed.connect (boost::bind (&ContentSubPanel::config_changed, this, _1));
}
void
-ContentSubPanel::setup_refer_button (wxCheckBox* button, shared_ptr<DCPContent> dcp, bool can_reference, list<string> why_not) const
+ContentSubPanel::config_changed (Config::Property p)
{
- /* 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
- );
+ if (p == Config::INTERFACE_COMPLEXITY) {
+ _grid->Clear ();
+ add_to_grid ();
+ _sizer->Layout ();
+ _grid->Layout ();
}
+}
+void
+ContentSubPanel::setup_refer_button (wxCheckBox* button, wxStaticText* note, shared_ptr<DCPContent> dcp, bool can_reference, string why_not) const
+{
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);
}
}
- /* XXX: more debugging */
- if (!s.IsEmpty()) {
- dcp->film()->log()->log (String::compose ("setting tooltip to %1", wx_to_std (s)), LogEntry::TYPE_GENERAL);
+ note->SetLabel (s);
+ note->Wrap (400);
+
+ if (s.IsEmpty ()) {
+ note->Hide ();
} else {
- dcp->film()->log()->log ("clearing tooltip", LogEntry::TYPE_GENERAL);
+ note->Show ();
}
- button->SetToolTip (s);
+ _sizer->Layout ();
}