X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/502fcfc68a0634e5d5bd586c9a89fe93dc0cbcc4..9925392e576717cc0df070ace822a6f392808bb7:/lib/python/Screens/EpgSelection.py diff --git a/lib/python/Screens/EpgSelection.py b/lib/python/Screens/EpgSelection.py index 440df528..def51d49 100644 --- a/lib/python/Screens/EpgSelection.py +++ b/lib/python/Screens/EpgSelection.py @@ -5,6 +5,10 @@ from Components.ActionMap import ActionMap from Screens.EventView import EventView from enigma import eServiceReference, eServiceEventPtr from Screens.FixedMenu import FixedMenu +from RecordTimer import RecordTimerEntry +from TimerEdit import TimerEditList +from TimerEntry import TimerEntry +from ServiceReference import ServiceReference import xml.dom.minidom @@ -22,6 +26,7 @@ class EPGSelection(Screen): { "cancel": self.close, "ok": self.eventSelected, + "timerAdd": self.timerAdd }) self["actions"].csel = self self.setRoot(root) @@ -36,10 +41,37 @@ class EPGSelection(Screen): def eventSelected(self): event = self["list"].getCurrent() - self.session.open(EventView, event, self.eventViewCallback) -# self.close() + self.session.open(EventView, event, self.currentService, self.eventViewCallback) + def timerAdd(self): + epg = self["list"].getCurrent() + + if (epg == None): + description = "unknown event" + else: + description = epg.getEventName() + # FIXME we need a timestamp here: + begin = epg.getBeginTime() + + print begin + print epg.getDuration() + end = begin + epg.getDuration() + + + # FIXME only works if already playing a service + serviceref = ServiceReference(self.session.nav.getCurrentlyPlayingServiceReference()) + + newEntry = RecordTimerEntry(begin, end, serviceref, epg, description) + self.session.openWithCallback(self.timerEditFinished, TimerEntry, newEntry) + + def timerEditFinished(self, answer): + if (answer[0]): + self.session.nav.RecordTimer.record(answer[1]) + else: + print "Timeredit aborted" + def setRoot(self, root): + self.currentService=ServiceReference(root) self["list"].setRoot(root) def moveUp(self):