Improve language setup.
authorCarl Hetherington <cth@carlh.net>
Mon, 25 Mar 2013 22:58:15 +0000 (22:58 +0000)
committerCarl Hetherington <cth@carlh.net>
Mon, 25 Mar 2013 22:58:15 +0000 (22:58 +0000)
src/lib/config.h
src/lib/util.cc
src/wx/config_dialog.cc
src/wx/config_dialog.h

index ee46166e6d9809e4a098dcba15175f25509f459f..011ca716faef1839a1227daaa14bd74ad50cab7b 100644 (file)
@@ -165,6 +165,10 @@ public:
        void set_language (std::string l) {
                _language = l;
        }
+
+       void unset_language () {
+               _language = boost::none;
+       }
        
        void write () const;
 
index 593d0e76043953abc1f306ac12c29f33d6ef43db..2e467125181afe6a3c75a2848d625c0101c8ce98 100644 (file)
@@ -271,7 +271,10 @@ dvdomatic_setup_i18n (string lang)
        putenv (e.c_str());
 
        bindtextdomain ("libdvdomatic", mo_path().string().c_str());
-#endif
+#else
+       /* Hack to silence warning */
+       lang.clear ();
+#endif 
 
 #ifdef DVDOMATIC_POSIX
        bindtextdomain ("libdvdomatic", POSIX_LOCALE_PREFIX);
index ea1a7319e8a440a514c0e150d5eef43482598209..36433611470ff7ee14f8f0ed2de7e2f7f45b49d8 100644 (file)
@@ -46,7 +46,8 @@ ConfigDialog::ConfigDialog (wxWindow* parent)
        wxFlexGridSizer* table = new wxFlexGridSizer (3, 6, 6);
        table->AddGrowableCol (1, 1);
 
-       add_label_to_sizer (table, this, _("User interface language"));
+       _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"));
@@ -149,6 +150,8 @@ 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") {
@@ -158,7 +161,10 @@ ConfigDialog::ConfigDialog (wxWindow* parent)
        } 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);
@@ -371,3 +377,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 ());
+}
index 8a3c81ec99ec8359c703882d7e4b210082849780..f6f3b3707db4c914e89f15347621cd0243afd4fb 100644 (file)
@@ -39,6 +39,7 @@ public:
        ConfigDialog (wxWindow *);
 
 private:
+       void set_language_changed (wxCommandEvent &);
        void language_changed (wxCommandEvent &);
        void tms_ip_changed (wxCommandEvent &);
        void tms_path_changed (wxCommandEvent &);
@@ -56,7 +57,9 @@ private:
        void server_selection_changed (wxListEvent &);
 
        void add_server_to_control (ServerDescription *);
+       void setup_language_sensitivity ();
 
+       wxCheckBox* _set_language;
        wxChoice* _language;
        wxTextCtrl* _tms_ip;
        wxTextCtrl* _tms_path;