Initial nag for interface complexity.
authorCarl Hetherington <cth@carlh.net>
Fri, 7 Sep 2018 12:07:06 +0000 (13:07 +0100)
committerCarl Hetherington <cth@carlh.net>
Fri, 7 Sep 2018 12:07:06 +0000 (13:07 +0100)
src/lib/config.cc
src/lib/config.h
src/tools/dcpomatic.cc
src/wx/initial_setup_dialog.cc [new file with mode: 0644]
src/wx/initial_setup_dialog.h [new file with mode: 0644]
src/wx/wscript

index 22eb5b0e2b49e01309184f17ce9f1965060884d7..8c76671d4f4062702e1be17ff4524595e8d49919 100644 (file)
@@ -162,7 +162,7 @@ Config::set_defaults ()
        _christie_password = optional<string>();
        _gdc_username = optional<string>();
        _gdc_password = optional<string>();
-       _interface_complexity = INTERFACE_FULL;
+       _interface_complexity = INTERFACE_SIMPLE;
 
        _allowed_dcp_frame_rates.clear ();
        _allowed_dcp_frame_rates.push_back (24);
index 58db9c2802175a728c29caa73e2f3c6a719534d7..c5ce59fbfe1342db479098b55fe90d5a2f623f74 100644 (file)
@@ -360,6 +360,8 @@ public:
                NAG_ENCRYPTED_METADATA,
                NAG_REMAKE_DECRYPTION_CHAIN,
                NAG_BAD_SIGNER_CHAIN,
+               /* Not really a nag but it's the same idea */
+               NAG_INITIAL_SETUP,
                NAG_COUNT
        };
 
index 3d4e5121d6fbca1abc61276c008a0e007844a727..ded95eb442ddda419a3d9d674fbdbfcc4e13f287 100644 (file)
@@ -45,6 +45,7 @@
 #include "wx/export_dialog.h"
 #include "wx/paste_dialog.h"
 #include "wx/focus_manager.h"
+#include "wx/initial_setup_dialog.h"
 #include "lib/film.h"
 #include "lib/config.h"
 #include "lib/util.h"
@@ -1394,6 +1395,14 @@ private:
                if (splash) {
                        splash->Destroy ();
                }
+
+               if (!Config::instance()->nagged(Config::NAG_INITIAL_SETUP)) {
+                       InitialSetupDialog* d = new InitialSetupDialog ();
+                       d->ShowModal ();
+                       d->Destroy ();
+                       Config::instance()->set_nagged(Config::NAG_INITIAL_SETUP, true);
+               }
+
                _frame->Show ();
 
                if (!_film_to_load.empty() && boost::filesystem::is_directory (_film_to_load)) {
diff --git a/src/wx/initial_setup_dialog.cc b/src/wx/initial_setup_dialog.cc
new file mode 100644 (file)
index 0000000..af29179
--- /dev/null
@@ -0,0 +1,79 @@
+/*
+    Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
+
+    This file is part of DCP-o-matic.
+
+    DCP-o-matic is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    DCP-o-matic is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+#include "initial_setup_dialog.h"
+#include "lib/config.h"
+#include <boost/bind.hpp>
+
+InitialSetupDialog::InitialSetupDialog ()
+       : wxDialog (0, wxID_ANY, _("DCP-o-matic setup"))
+{
+       wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL);
+       wxStaticText* text1 = new wxStaticText (this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxSize(600, -1));
+       sizer->Add (text1, 1, wxEXPAND | wxALL, 12);
+
+       text1->SetLabelMarkup (
+               _(
+                       "<span weight=\"bold\" size=\"larger\">Welcome to DCP-o-matic!</span>\n\n"
+                       "DCP-o-matic can work in two modes: '<i>simple</i>' or '<i>full</i>'.\n\n"
+                       "<i>Simple mode</i> is ideal for producing straightforward DCPs without too many confusing "
+                       "options.\n\n"
+                       "<i>Full mode</i> gives you the most control over the DCPs you make.\n\n"
+                       "Please choose which mode you would like to start DCP-o-matic in:\n\n"
+                       )
+               );
+
+       _simple = new wxRadioButton (this, wxID_ANY, _("Simple mode"), wxDefaultPosition, wxDefaultSize, wxRB_GROUP);
+       sizer->Add (_simple, 0, wxLEFT, 24);
+       _full = new wxRadioButton (this, wxID_ANY, _("Full mode"));
+       sizer->Add (_full, 0, wxLEFT, 24);
+
+       if (Config::instance()->interface_complexity() == Config::INTERFACE_SIMPLE) {
+               _simple->SetValue (true);
+       } else {
+               _full->SetValue (true);
+       }
+
+       wxStaticText* text2 = new wxStaticText (this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxSize(400, -1));
+       sizer->Add (text2, 0, wxEXPAND | wxALL, 12);
+
+       text2->SetLabelMarkup (_("\nYou can change the mode at any time from the General page of Preferences."));
+
+       _simple->Bind (wxEVT_RADIOBUTTON, boost::bind(&InitialSetupDialog::interface_complexity_changed, this));
+       _full->Bind (wxEVT_RADIOBUTTON, boost::bind(&InitialSetupDialog::interface_complexity_changed, this));
+
+       wxSizer* buttons = CreateSeparatedButtonSizer (wxOK);
+       if (buttons) {
+               sizer->Add(buttons, wxSizerFlags().Expand().DoubleBorder());
+       }
+
+       sizer->Layout ();
+       SetSizerAndFit (sizer);
+}
+
+void
+InitialSetupDialog::interface_complexity_changed ()
+{
+       if (_simple->GetValue()) {
+               Config::instance()->set_interface_complexity (Config::INTERFACE_SIMPLE);
+       } else {
+               Config::instance()->set_interface_complexity (Config::INTERFACE_FULL);
+       }
+}
diff --git a/src/wx/initial_setup_dialog.h b/src/wx/initial_setup_dialog.h
new file mode 100644 (file)
index 0000000..3dfdbe2
--- /dev/null
@@ -0,0 +1,33 @@
+/*
+    Copyright (C) 2018 Carl Hetherington <cth@carlh.net>
+
+    This file is part of DCP-o-matic.
+
+    DCP-o-matic is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    DCP-o-matic is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with DCP-o-matic.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
+
+#include <wx/wx.h>
+
+class InitialSetupDialog : public wxDialog
+{
+public:
+       InitialSetupDialog ();
+
+private:
+       void interface_complexity_changed ();
+
+       wxRadioButton* _simple;
+       wxRadioButton* _full;
+};
index 91dc4ba87144c9dfd3958b9dd6e986372966584b..f262d0cf92f8d6cfb92197a3603422c2d601e865 100644 (file)
@@ -71,6 +71,7 @@ sources = """
           gain_calculator_dialog.cc
           gdc_certificate_panel.cc
           hints_dialog.cc
+          initial_setup_dialog.cc
           job_view.cc
           job_view_dialog.cc
           job_manager_view.cc