- if (!job) {
- return;
- }
-
- wxStaticText* m = new wxStaticText (_panel, wxID_ANY, std_to_wx (job->name ()));
- _table->Insert (0, m, 0, wxALIGN_CENTER_VERTICAL | wxALL, 6);
-
- JobRecord r;
- int n = 1;
- r.scroll_nudged = false;
- r.gauge = new wxGauge (_panel, wxID_ANY, 100);
- _table->Insert (n, r.gauge, 1, wxEXPAND | wxLEFT | wxRIGHT);
- ++n;
-
- r.message = new wxStaticText (_panel, wxID_ANY, std_to_wx (""));
- _table->Insert (n, r.message, 1, wxALIGN_CENTER_VERTICAL | wxALL, 6);
- ++n;
-
- r.cancel = new wxButton (_panel, wxID_ANY, _("Cancel"));
- r.cancel->Connect (wxID_ANY, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (JobManagerView::cancel_clicked), 0, this);
- _table->Insert (n, r.cancel, 1, wxALIGN_CENTER_VERTICAL | wxALL, 6);
- ++n;
-
- if (_buttons & PAUSE) {
- r.pause = new wxButton (_panel, wxID_ANY, _("Pause"));
- r.pause->Connect (wxID_ANY, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (JobManagerView::pause_clicked), 0, this);
- _table->Insert (n, r.pause, 1, wxALIGN_CENTER_VERTICAL | wxALL, 6);
- ++n;
- }
-
- r.details = new wxButton (_panel, wxID_ANY, _("Details..."));
- r.details->Connect (wxID_ANY, wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler (JobManagerView::details_clicked), 0, this);
- r.details->Enable (false);
- _table->Insert (n, r.details, 1, wxALIGN_CENTER_VERTICAL | wxALL, 6);
- ++n;
-
- _job_records[job] = r;
-
- job->Progress.connect (bind (&JobManagerView::progress, this, j));
- job->Progress.connect (bind (&JobManagerView::finished, this, j));
-
- _table->Layout ();
- FitInside ();
-}
-
-void
-JobManagerView::progress (weak_ptr<Job> j)
-{
- shared_ptr<Job> job = j.lock ();
- if (!job) {
- return;
- }
-
- float const p = job->overall_progress ();
- if (p >= 0) {
- checked_set (_job_records[job].message, job->status ());
- _job_records[job].gauge->SetValue (p * 100);
- } else {
- checked_set (_job_records[job].message, wx_to_std (_("Running")));
- _job_records[job].gauge->Pulse ();
- }
-
- if (!_job_records[job].scroll_nudged && (job->running () || job->finished())) {
- int x, y;
- _job_records[job].gauge->GetPosition (&x, &y);
- int px, py;
- GetScrollPixelsPerUnit (&px, &py);
- int vx, vy;
- GetViewStart (&vx, &vy);
- int sx, sy;
- GetClientSize (&sx, &sy);
-
- if (y > (vy * py + sy / 2)) {
- Scroll (-1, y / py);
- _job_records[job].scroll_nudged = true;