Merge branch 'master' into content-rework-take5
[dcpomatic.git] / src / wx / config_dialog.cc
index 07e32a4578a0ecd44a2d825a4e97c03265c770e5..c3eebc01515451d5a33529926bc6f039c6cbd166 100644 (file)
@@ -18,7 +18,7 @@
 */
 
 /** @file src/config_dialog.cc
- *  @brief A dialogue to edit DVD-o-matic configuration.
+ *  @brief A dialogue to edit DCP-o-matic configuration.
  */
 
 #include <iostream>
@@ -41,11 +41,30 @@ using namespace std;
 using boost::bind;
 
 ConfigDialog::ConfigDialog (wxWindow* parent)
-       : wxDialog (parent, wxID_ANY, _("DVD-o-matic Preferences"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
+       : wxDialog (parent, wxID_ANY, _("DCP-o-matic Preferences"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
 {
        wxFlexGridSizer* table = new wxFlexGridSizer (3, 6, 6);
        table->AddGrowableCol (1, 1);
 
+       _set_language = new wxCheckBox (this, wxID_ANY, _("Set language"));
+       table->Add (_set_language, 1, wxEXPAND);
+       _language = new wxChoice (this, wxID_ANY);
+       _language->Append (wxT ("English"));
+       _language->Append (wxT ("Français"));
+       _language->Append (wxT ("Italiano"));
+       _language->Append (wxT ("Español"));
+       _language->Append (wxT ("Svenska"));
+       table->Add (_language, 1, wxEXPAND);
+       table->AddSpacer (0);
+
+       table->AddSpacer (0);
+       wxStaticText* restart = add_label_to_sizer (table, this, _("(restart DCP-o-matic to see language changes)"));
+       wxFont font = restart->GetFont();
+       font.SetStyle (wxFONTSTYLE_ITALIC);
+       font.SetPointSize (font.GetPointSize() - 1);
+       restart->SetFont (font);
+       table->AddSpacer (0);
+
        add_label_to_sizer (table, this, _("TMS IP address"));
        _tms_ip = new wxTextCtrl (this, wxID_ANY);
        table->Add (_tms_ip, 1, wxEXPAND);
@@ -132,6 +151,24 @@ ConfigDialog::ConfigDialog (wxWindow* parent)
                
        Config* config = Config::instance ();
 
+       _set_language->SetValue (config->language ());
+
+       if (config->language().get_value_or ("") == "fr") {
+               _language->SetSelection (1);
+       } else if (config->language().get_value_or ("") == "it") {
+               _language->SetSelection (2);
+       } else if (config->language().get_value_or ("") == "es") {
+               _language->SetSelection (3);
+       } else if (config->language().get_value_or ("") == "sv") {
+               _language->SetSelection (4);
+       } else {
+               _language->SetSelection (0);
+       }
+
+       setup_language_sensitivity ();
+
+       _set_language->Connect (wxID_ANY, wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler (ConfigDialog::set_language_changed), 0, this);
+       _language->Connect (wxID_ANY, wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler (ConfigDialog::language_changed), 0, this);
        _tms_ip->SetValue (std_to_wx (config->tms_ip ()));
        _tms_ip->Connect (wxID_ANY, wxEVT_COMMAND_TEXT_UPDATED, wxCommandEventHandler (ConfigDialog::tms_ip_changed), 0, this);
        _tms_path->SetValue (std_to_wx (config->tms_path ()));
@@ -154,7 +191,7 @@ ConfigDialog::ConfigDialog (wxWindow* parent)
        _reference_scaler->Connect (wxID_ANY, wxEVT_COMMAND_CHOICE_SELECTED, wxCommandEventHandler (ConfigDialog::reference_scaler_changed), 0, this);
 
        pair<string, string> p = Filter::ffmpeg_strings (config->reference_filters ());
-       _reference_filters->SetLabel (std_to_wx (p.first + " " + p.second));
+       _reference_filters->SetLabel (std_to_wx (p.first) + N_(" ") + std_to_wx (p.second));
        _reference_filters_button->Connect (wxID_ANY, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (ConfigDialog::edit_reference_filters_clicked), 0, this);
 
        vector<ServerDescription*> servers = config->servers ();
@@ -184,6 +221,28 @@ ConfigDialog::ConfigDialog (wxWindow* parent)
        overall_sizer->SetSizeHints (this);
 }
 
+void
+ConfigDialog::language_changed (wxCommandEvent &)
+{
+       switch (_language->GetSelection ()) {
+       case 0:
+               Config::instance()->set_language ("en");
+               break;
+       case 1:
+               Config::instance()->set_language ("fr");
+               break;
+       case 2:
+               Config::instance()->set_language ("it");
+               break;
+       case 3:
+               Config::instance()->set_language ("es");
+               break;
+       case 4:
+               Config::instance()->set_language ("sv");
+               break;
+       }
+}
+
 void
 ConfigDialog::tms_ip_changed (wxCommandEvent &)
 {
@@ -313,7 +372,7 @@ ConfigDialog::reference_filters_changed (vector<Filter const *> f)
 {
        Config::instance()->set_reference_filters (f);
        pair<string, string> p = Filter::ffmpeg_strings (Config::instance()->reference_filters ());
-       _reference_filters->SetLabel (std_to_wx (p.first + " " + p.second));
+       _reference_filters->SetLabel (std_to_wx (p.first) + N_(" ") + std_to_wx (p.second));
 }
 
 void
@@ -324,3 +383,20 @@ ConfigDialog::edit_default_dci_metadata_clicked (wxCommandEvent &)
        Config::instance()->set_default_dci_metadata (d->dci_metadata ());
        d->Destroy ();
 }
+
+void
+ConfigDialog::set_language_changed (wxCommandEvent& ev)
+{
+       setup_language_sensitivity ();
+       if (_set_language->GetValue ()) {
+               language_changed (ev);
+       } else {
+               Config::instance()->unset_language ();
+       }
+}
+
+void
+ConfigDialog::setup_language_sensitivity ()
+{
+       _language->Enable (_set_language->GetValue ());
+}