X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fname_format_editor.h;h=e3728615fcf818e14bce5c92336c99a1addaca63;hb=1701253912a8a6fcec87447b58efa53cacbac4b4;hp=71295807fda83b7be874448e172494f32b02d1a5;hpb=49fc9b8c4282d0e973ac1f4e31357735cf6be218;p=dcpomatic.git diff --git a/src/wx/name_format_editor.h b/src/wx/name_format_editor.h index 71295807f..e3728615f 100644 --- a/src/wx/name_format_editor.h +++ b/src/wx/name_format_editor.h @@ -22,47 +22,23 @@ #define DCPOMATIC_NAME_FORMAT_EDITOR_H #include "lib/compose.hpp" +#include "lib/warnings.h" #include +DCPOMATIC_DISABLE_WARNINGS #include -#include +DCPOMATIC_ENABLE_WARNINGS +#include -template class NameFormatEditor { public: - NameFormatEditor (wxWindow* parent, T name, dcp::NameFormat::Map titles, dcp::NameFormat::Map examples) - : _panel (new wxPanel (parent)) - , _example (new wxStaticText (_panel, wxID_ANY, "")) - , _sizer (new wxBoxSizer (wxVERTICAL)) - , _specification (new wxTextCtrl (_panel, wxID_ANY, "")) - , _name (name) - , _examples (examples) - { - _sizer->Add (_specification, 0, wxEXPAND, DCPOMATIC_SIZER_Y_GAP); - _sizer->Add (_example, 0, wxBOTTOM, DCPOMATIC_SIZER_Y_GAP); - _panel->SetSizer (_sizer); - - BOOST_FOREACH (char c, name.components ()) { - wxStaticText* t = new wxStaticText (_panel, wxID_ANY, std_to_wx (String::compose ("%%%1 %2", c, titles[c]))); - _sizer->Add (t); - wxFont font = t->GetFont(); - font.SetStyle (wxFONTSTYLE_ITALIC); - font.SetPointSize (font.GetPointSize() - 1); - t->SetFont (font); - t->SetForegroundColour (wxColour (0, 0, 204)); - } - - _specification->SetValue (std_to_wx (_name.specification ())); - _specification->Bind (wxEVT_COMMAND_TEXT_UPDATED, boost::bind (&NameFormatEditor::changed, this)); - - update_example (); - } + NameFormatEditor (wxWindow* parent, dcp::NameFormat name, dcp::NameFormat::Map titles, dcp::NameFormat::Map examples, std::string suffix); wxPanel* panel () const { return _panel; } - T get () const { + dcp::NameFormat get () const { return _name; } @@ -70,35 +46,17 @@ public: private: - void changed () - { - update_example (); - Changed (); - } - - virtual void update_example () - { - _name.set_specification (wx_to_std (_specification->GetValue ())); - - wxString example = wxString::Format (_("e.g. %s"), _name.get (_examples)); - wxString wrapped; - for (size_t i = 0; i < example.Length(); ++i) { - if (i > 0 && (i % 40) == 0) { - wrapped += "\n"; - } - wrapped += example[i]; - } - - _example->SetLabel (wrapped); - } + void changed (); + void update_example (); wxPanel* _panel; wxStaticText* _example; wxSizer* _sizer; wxTextCtrl* _specification; - T _name; + dcp::NameFormat _name; dcp::NameFormat::Map _examples; + std::string _suffix; }; #endif