*/
+
#include "job_view.h"
#include "wx_util.h"
#include "message_dialog.h"
#include <wx/wx.h>
#include <boost/algorithm/string.hpp>
+
using std::string;
using std::min;
-using boost::shared_ptr;
+using std::shared_ptr;
using boost::bind;
-using boost::dynamic_pointer_cast;
+
JobView::JobView (shared_ptr<Job> job, wxWindow* parent, wxWindow* container, wxFlexGridSizer* table)
: _job (job)
}
+
void
JobView::setup ()
{
_cancel = new Button (_container, _("Cancel"));
_cancel->Bind (wxEVT_BUTTON, &JobView::cancel_clicked, this);
- _buttons->Add (_cancel, 1, wxALIGN_CENTER_VERTICAL);
+ _buttons->Add (_cancel, 1, wxALIGN_CENTER_VERTICAL | wxRIGHT, DCPOMATIC_BUTTON_STACK_GAP);
_details = new Button (_container, _("Details..."));
_details->Bind (wxEVT_BUTTON, &JobView::details_clicked, this);
_details->Enable (false);
- _buttons->Add (_details, 1, wxALIGN_CENTER_VERTICAL);
+ _buttons->Add (_details, 1, wxALIGN_CENTER_VERTICAL | wxRIGHT, DCPOMATIC_BUTTON_STACK_GAP);
finish_setup (_container, _buttons);
_notify = new CheckBox (_container, _("Notify when complete"));
_notify->Bind (wxEVT_CHECKBOX, bind (&JobView::notify_clicked, this));
_notify->SetValue (Config::instance()->default_notify());
- _controls->Add (_notify);
+ _controls->Add (_notify, 0, wxTOP, DCPOMATIC_BUTTON_STACK_GAP);
_table->Insert (n, _controls, 1, wxALIGN_CENTER_VERTICAL | wxALL, 3);
_table->Layout ();
}
+
void
JobView::maybe_pulse ()
{
- if (_gauge && _job->running() && !_job->progress()) {
- _gauge->Pulse ();
+ if (_gauge && _job->running()) {
+ auto elapsed = _job->seconds_since_last_progress_update();
+ if (!_job->progress() || !elapsed || *elapsed > 2) {
+ _gauge->Pulse ();
+ }
}
}
+
void
JobView::progress ()
{
if (!_job->sub_name().empty ()) {
whole += _job->sub_name() + " ";
}
- string s = _job->status ();
+ auto s = _job->status ();
/* Watch out for < > in the error string */
boost::algorithm::replace_all (s, "<", "<");
boost::algorithm::replace_all (s, ">", ">");
}
}
+
void
JobView::finished ()
{
}
if (_job->message()) {
- MessageDialog* d = new MessageDialog (_parent, _job->name(), _job->message().get());
+ auto d = new MessageDialog (_parent, std_to_wx(_job->name()), std_to_wx(_job->message().get()));
d->ShowModal ();
d->Destroy ();
}
- if ((dynamic_pointer_cast<TranscodeJob>(_job) || dynamic_pointer_cast<AnalyseAudioJob>(_job)) && _notify->GetValue()) {
+ if (_job->enable_notify() && _notify->GetValue()) {
if (Config::instance()->notification(Config::MESSAGE_BOX)) {
wxMessageBox (std_to_wx(_job->name() + ": " + _job->status()), _("DCP-o-matic"), wxICON_INFORMATION);
}
}
}
+
void
JobView::details_clicked (wxCommandEvent &)
{
- string s = _job->error_summary();
+ auto s = _job->error_summary();
s[0] = toupper (s[0]);
error_dialog (_parent, std_to_wx(s), std_to_wx(_job->error_details()));
}
+
void
JobView::cancel_clicked (wxCommandEvent &)
{
}
}
+
void
JobView::insert (int pos)
{
_table->Layout ();
}
+
void
JobView::detach ()
{
_table->Detach (_controls);
}
+
void
JobView::notify_clicked ()
{