properly use rcused config element
[enigma2.git] / lib / python / Screens / TaskView.py
index 252858529c28e739eae7d73e0cdd15e755aeea6f..790e9bc68ea52ffdd70846539d67cbf3120c8e0e 100644 (file)
@@ -1,18 +1,23 @@
 from Screen import Screen
+from InfoBarGenerics import InfoBarNotifications
 
-class JobView(Screen):
+class JobView(InfoBarNotifications, Screen):
        def __init__(self, session, job, cancelable = True, close_on_finish = False):
                from Components.Sources.StaticText import StaticText
                from Components.Sources.Progress import Progress
+               from Components.Sources.Boolean import Boolean
                from Components.ActionMap import ActionMap
                Screen.__init__(self, session)
+               InfoBarNotifications.__init__(self)
                self.job = job
                self.close_on_finish = close_on_finish
+               self.cancelable = cancelable
 
                self["job_name"] = StaticText(job.name)
                self["job_progress"] = Progress()
                self["job_status"] = StaticText()
                self["job_task"] = StaticText()
+               self["finished"] = Boolean()
 
                self.onShow.append(self.windowShow)
                self.onHide.append(self.windowHide)
@@ -28,19 +33,24 @@ class JobView(Screen):
                self.state_changed()
 
        def windowHide(self):
-               self.job.state_changed.remove(self.state_changed)
+               if len(self.job.state_changed) > 0:
+                   self.job.state_changed.remove(self.state_changed)
 
        def state_changed(self):
                j = self.job
-               self["job_progress"].range = len(j.tasks)
-               self["job_progress"].value = j.current_task
+               self["job_progress"].range = j.end
+               self["job_progress"].value = j.progress
+               print "JobView::state_changed:", j.end, j.progress
                self["job_status"].text = {j.NOT_STARTED: _("Waiting"), j.IN_PROGRESS: _("In Progress"), j.FINISHED: _("Finished"), j.FAILED: _("Failed")}[j.status]
                if j.status == j.IN_PROGRESS:
                        self["job_task"].text = j.tasks[j.current_task].name
                else:
                        self["job_task"].text = ""
-               if j.status in [j.FINISHED, j.FAILED] and self.close_on_finish:
-                       self.close()
+               if j.status in [j.FINISHED, j.FAILED]:
+                       if self.close_on_finish:
+                               self.close()
+                       else:
+                               self["finished"].boolean = True
 
        def ok(self):
                if self.job.status in [self.job.FINISHED, self.job.FAILED]: