X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fpython%2FScreens%2FTimerEdit.py;h=681d3a2580687f000788c38da340522ba10edf87;hp=018e28dc09d6815acc7bc4408e38b9098714e236;hb=e03c732afb410b4d6b9f9540c36c33c941ee38f1;hpb=e1342ca063df18d3b933420150d06b86ea506bb3 diff --git a/lib/python/Screens/TimerEdit.py b/lib/python/Screens/TimerEdit.py index 018e28d..681d3a2 100644 --- a/lib/python/Screens/TimerEdit.py +++ b/lib/python/Screens/TimerEdit.py @@ -1,17 +1,14 @@ from Screen import Screen from Components.TimerList import TimerList, TimerEntryComponent -from Components.ConfigList import ConfigList from Components.MenuList import MenuList from Components.ActionMap import ActionMap -from Components.TimeInput import TimeInput from Components.Label import Label from Components.Button import Button from Screens.MessageBox import MessageBox from TimerEntry import TimerEntry, TimerLog -from RecordTimer import RecordTimerEntry, parseEvent +from RecordTimer import RecordTimerEntry, parseEvent, AFTEREVENT from time import * from ServiceReference import ServiceReference -from Components.config import * from Components.TimerSanityCheck import TimerSanityCheck class TimerEditList(Screen): @@ -33,7 +30,7 @@ class TimerEditList(Screen): { "ok": self.openEdit, "cancel": self.leave, - "red": self.removeTimer, + "red": self.removeTimerQuestion, "green": self.addCurrentTimer, "blue": self.cleanupQuestion, "yellow": self.toggleDisabledState, @@ -63,10 +60,18 @@ class TimerEditList(Screen): self.updateState() def toggleDisabledState(self): - self["timerlist"].getCurrent()[0].disabled = not self["timerlist"].getCurrent()[0].disabled - self.session.nav.RecordTimer.timeChanged(self["timerlist"].getCurrent()[0]) - self.updateState() - self.refill() + cur=self["timerlist"].getCurrent() + if cur: + t = cur[0] + + if t.disabled: + t.enable() + else: + t.disable() + + self.session.nav.RecordTimer.timeChanged(t) + self.updateState() + self.refill() def updateState(self): if len(self.list) > 0: @@ -87,12 +92,15 @@ class TimerEditList(Screen): self.list.sort(cmp = lambda x, y: x[0].begin < y[0].begin) def showLog(self): - self.session.openWithCallback(self.finishedEdit, TimerLog, self["timerlist"].getCurrent()[0]) + cur=self["timerlist"].getCurrent() + if cur: + self.session.openWithCallback(self.finishedEdit, TimerLog, cur[0]) def openEdit(self): - self.session.openWithCallback(self.finishedEdit, TimerEntry, self["timerlist"].getCurrent()[0]) - #self.session.open(TimerEdit, self["timerlist"].getCurrent()[0]) - + cur=self["timerlist"].getCurrent() + if cur: + self.session.openWithCallback(self.finishedEdit, TimerEntry, cur[0]) + def cleanupQuestion(self): self.session.openWithCallback(self.cleanupTimer, MessageBox, _("Really delete done timers?")) @@ -100,12 +108,20 @@ class TimerEditList(Screen): if delete: self.session.nav.RecordTimer.cleanup() self.refill() + + def removeTimerQuestion(self): + self.session.openWithCallback(self.removeTimer, MessageBox, _("Really delete this timer?")) - def removeTimer(self): + def removeTimer(self, result): + if not result: + return list = self["timerlist"] - timer = list.getCurrent()[0] - self.session.nav.RecordTimer.removeEntry(timer) - self.refill() + cur = list.getCurrent() + if cur: + timer = cur[0] + timer.afterEvent = AFTEREVENT.NONE + self.session.nav.RecordTimer.removeEntry(timer) + self.refill() def refill(self): self.fillTimerList() @@ -127,7 +143,7 @@ class TimerEditList(Screen): else: data = parseEvent(event) - self.addTimer(RecordTimerEntry(serviceref, *data)) + self.addTimer(RecordTimerEntry(serviceref, checkOldTimers = True, *data)) def addTimer(self, timer): self.session.openWithCallback(self.finishedAdd, TimerEntry, timer)