X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0e9ffe6bc88f7cec210e0416f36062eb0c7a3502..4f46a90d789f28eb0ca156caeb2bb55136d8ac85:/lib/python/Screens/TimerEdit.py diff --git a/lib/python/Screens/TimerEdit.py b/lib/python/Screens/TimerEdit.py index 6f050aae..73733913 100644 --- a/lib/python/Screens/TimerEdit.py +++ b/lib/python/Screens/TimerEdit.py @@ -6,7 +6,7 @@ from Components.Label import Label from Components.Button import Button from Components.TextInput import TextInput from TimerEntry import TimerEntry -from RecordTimer import RecordTimerEntry +from RecordTimer import RecordTimerEntry, parseEvent from time import * from ServiceReference import ServiceReference from Components.config import * @@ -21,15 +21,15 @@ class TimerEditList(Screen): self["timerlist"] = TimerList(list) - self["key_red"] = Button("Delete") - self["key_green"] = Button("Add") + self["key_red"] = Button(_("Delete")) + self["key_green"] = Button(_("Add")) self["key_yellow"] = Button("") self["key_blue"] = Button("") self["actions"] = ActionMap(["OkCancelActions", "ShortcutActions"], { "ok": self.openEdit, - "cancel": self.close, + "cancel": self.leave, "red": self.removeTimer, "green": self.addCurrentTimer }) @@ -51,37 +51,25 @@ class TimerEditList(Screen): # FIXME doesn't work... self.session.nav.RecordTimer.removeEntry(self["timerlist"].getCurrent()[0]) self.fillTimerList() - self["timerlist"].l.invalidate() + self["timerlist"].invalidate() def addCurrentTimer(self): - begin = time() - end = time() + 60 - - epg = None - try: - service = self.session.nav.getCurrentService() + event = None + service = self.session.nav.getCurrentService() + if service is not None: info = service.info() - ev = info.getEvent(0) - epg = ev - except: - pass - - if (epg == None): - description = "unknown event" - else: - description = ev.getEventName() - # FIXME we need a timestamp here: - begin = ev.getBeginTime() - - print begin - print ev.getDuration() - end = begin + ev.getDuration() - + if info is not None: + event = info.getEvent(0) # FIXME only works if already playing a service serviceref = ServiceReference(self.session.nav.getCurrentlyPlayingServiceReference()) - self.addTimer(RecordTimerEntry(begin, end, serviceref, epg, description)) + if event is None: + data = (int(time()), int(time() + 60), "unknown event", "", None) + else: + data = parseEvent(event) + + self.addTimer(RecordTimerEntry(serviceref, *data)) def addTimer(self, timer): self.session.openWithCallback(self.finishedAdd, TimerEntry, timer) @@ -89,6 +77,7 @@ class TimerEditList(Screen): def finishedEdit(self, answer): if (answer[0]): print "Edited timer" + self.session.nav.RecordTimer.timeChanged(answer[1]) self.fillTimerList() else: print "Timeredit aborted" @@ -99,3 +88,7 @@ class TimerEditList(Screen): self.fillTimerList() else: print "Timeredit aborted" + + def leave(self): + self.session.nav.RecordTimer.saveTimer() + self.close()