X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fupdate_dialog.cc;h=c88ddbff2f46cc026045585d688167ea52c3bc1f;hb=723b49e77951d0981b8165f724acd49d9a44660d;hp=271c4174c611a441197c889a0dd9a081b490fba1;hpb=e8204f55c981493b99814f71a50b3c3d62601032;p=dcpomatic.git diff --git a/src/wx/update_dialog.cc b/src/wx/update_dialog.cc index 271c4174c..c88ddbff2 100644 --- a/src/wx/update_dialog.cc +++ b/src/wx/update_dialog.cc @@ -1,19 +1,20 @@ /* Copyright (C) 2012 Carl Hetherington - This program is free software; you can redistribute it and/or modify + 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. - This program is distributed in the hope that it will be useful, + 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 this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -22,15 +23,16 @@ #include "wx_util.h" using std::string; +using boost::optional; -UpdateDialog::UpdateDialog (wxWindow* parent, string stable, string test) +UpdateDialog::UpdateDialog (wxWindow* parent, optional stable, optional test) : wxDialog (parent, wxID_ANY, _("Update")) { wxBoxSizer* overall_sizer = new wxBoxSizer (wxVERTICAL); wxStaticText* message; - if (test.empty ()) { + if ((stable || test) && !(stable && test)) { message = new wxStaticText (this, wxID_ANY, _("A new version of DCP-o-matic is available.")); } else { message = new wxStaticText (this, wxID_ANY, _("New versions of DCP-o-matic are available.")); @@ -40,22 +42,24 @@ UpdateDialog::UpdateDialog (wxWindow* parent, string stable, string test) wxFlexGridSizer* table = new wxFlexGridSizer (2, DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); - add_label_to_sizer (table, this, _("Stable version ") + std_to_wx (stable), true); - wxHyperlinkCtrl* h = new wxHyperlinkCtrl (this, wxID_ANY, "dcpomatic.com/download", "http://dcpomatic.com/download"); - table->Add (h); - - if (!test.empty ()) { - add_label_to_sizer (table, this, _("Test version ") + std_to_wx (test), true); + if (stable) { + add_label_to_sizer (table, this, _("Stable version ") + std_to_wx (stable.get ()), true); + wxHyperlinkCtrl* h = new wxHyperlinkCtrl (this, wxID_ANY, "dcpomatic.com/download", "http://dcpomatic.com/download"); + table->Add (h); + } + + if (test) { + add_label_to_sizer (table, this, _("Test version ") + std_to_wx (test.get ()), true); wxHyperlinkCtrl* h = new wxHyperlinkCtrl (this, wxID_ANY, "dcpomatic.com/test-download", "http://dcpomatic.com/test-download"); table->Add (h); } - - overall_sizer->Add (table, 1, wxEXPAND | wxLEFT | wxRIGHT, DCPOMATIC_DIALOG_BORDER); + + overall_sizer->Add (table, 1, wxEXPAND | wxLEFT | wxRIGHT | wxTOP, DCPOMATIC_DIALOG_BORDER); wxSizer* buttons = CreateButtonSizer (wxOK); if (buttons) { overall_sizer->Add (buttons, 1, wxEXPAND | wxALL); } - + SetSizerAndFit (overall_sizer); }