/*
Copyright (C) 2012-2015 Carl Hetherington <cth@carlh.net>
- 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 <http://www.gnu.org/licenses/>.
*/
JobView::JobView (shared_ptr<Job> job, wxWindow* parent, wxWindow* container, wxFlexGridSizer* table)
: _job (job)
+ , _table (table)
, _parent (parent)
+ , _container (container)
+{
+
+}
+
+void
+JobView::setup ()
{
- int n = 0;
+ int n = insert_position ();
_gauge_message = new wxBoxSizer (wxVERTICAL);
- _gauge = new wxGauge (container, wxID_ANY, 100);
+ _gauge = new wxGauge (_container, wxID_ANY, 100);
/* This seems to be required to allow the gauge to shrink under OS X */
_gauge->SetMinSize (wxSize (0, -1));
_gauge_message->Add (_gauge, 0, wxEXPAND | wxLEFT | wxRIGHT);
- _message = new wxStaticText (container, wxID_ANY, wxT (" \n "));
+ _message = new wxStaticText (_container, wxID_ANY, wxT (" \n "), wxDefaultPosition, wxDefaultSize, wxST_ELLIPSIZE_MIDDLE);
_gauge_message->Add (_message, 1, wxEXPAND | wxALIGN_CENTER_VERTICAL | wxALL, 6);
- table->Insert (n, _gauge_message, 1, wxEXPAND | wxLEFT | wxRIGHT);
+ _table->Insert (n, _gauge_message, 1, wxEXPAND | wxLEFT | wxRIGHT);
++n;
- _cancel = new wxButton (container, wxID_ANY, _("Cancel"));
- _cancel->Bind (wxEVT_COMMAND_BUTTON_CLICKED, &JobView::cancel_clicked, this);
- table->Insert (n, _cancel, 1, wxALIGN_CENTER_VERTICAL | wxALL, 3);
- ++n;
+ wxBoxSizer* buttons = new wxBoxSizer (wxHORIZONTAL);
- _pause = new wxButton (container, wxID_ANY, _("Pause"));
- _pause->Bind (wxEVT_COMMAND_BUTTON_CLICKED, &JobView::pause_clicked, this);
- table->Insert (n, _pause, 1, wxALIGN_CENTER_VERTICAL | wxALL, 3);
- ++n;
+ _cancel = new wxButton (_container, wxID_ANY, _("Cancel"));
+ _cancel->Bind (wxEVT_BUTTON, &JobView::cancel_clicked, this);
+ buttons->Add (_cancel, 1, wxALIGN_CENTER_VERTICAL);
- _details = new wxButton (container, wxID_ANY, _("Details..."));
- _details->Bind (wxEVT_COMMAND_BUTTON_CLICKED, &JobView::details_clicked, this);
+ _details = new wxButton (_container, wxID_ANY, _("Details..."));
+ _details->Bind (wxEVT_BUTTON, &JobView::details_clicked, this);
_details->Enable (false);
- table->Insert (n, _details, 1, wxALIGN_CENTER_VERTICAL | wxALL, 3);
- ++n;
+ buttons->Add (_details, 1, wxALIGN_CENTER_VERTICAL);
+
+ finish_setup (_container, buttons);
- _progress_connection = job->Progress.connect (boost::bind (&JobView::progress, this));
- _finished_connection = job->Finished.connect (boost::bind (&JobView::finished, this));
+ _table->Insert (n, buttons, 1, wxALIGN_CENTER_VERTICAL | wxALL, 3);
+
+ _progress_connection = _job->Progress.connect (boost::bind (&JobView::progress, this));
+ _finished_connection = _job->Finished.connect (boost::bind (&JobView::finished, this));
progress ();
- table->Layout ();
+ _table->Layout ();
}
void
whole += _job->status ();
if (whole != _last_message) {
_message->SetLabelMarkup (std_to_wx (whole));
+ /* This hack fixes the size of _message on OS X */
+ _message->InvalidateBestSize ();
+ _message->SetSize (_message->GetBestSize ());
_gauge_message->Layout ();
_last_message = whole;
}
}
_cancel->Enable (false);
- _pause->Enable (false);
if (!_job->error_details().empty ()) {
_details->Enable (true);
}
void
JobView::cancel_clicked (wxCommandEvent &)
{
- _job->cancel ();
-}
-
-void
-JobView::pause_clicked (wxCommandEvent &)
-{
- if (_job->paused()) {
- _job->resume ();
- _pause->SetLabel (_("Pause"));
- } else {
- _job->pause ();
- _pause->SetLabel (_("Resume"));
+ if (confirm_dialog (_parent, _("Are you sure you want to cancel this job?"))) {
+ _job->cancel ();
}
}