X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/803d9e3bf21e233a3100ed32904d9035e67774a9..f965acae25306290600029c8c402b9429ea2e196:/lib/python/Screens/TaskView.py diff --git a/lib/python/Screens/TaskView.py b/lib/python/Screens/TaskView.py index 25285852..790e9bc6 100644 --- a/lib/python/Screens/TaskView.py +++ b/lib/python/Screens/TaskView.py @@ -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]: